GVKun编程网logo

使用 InAppWebView 从内部存储加载 HTML 文件(app内嵌webview)

29

在本文中,我们将详细介绍使用InAppWebView从内部存储加载HTML文件的各个方面,并为您提供关于app内嵌webview的相关解答,同时,我们也将为您带来关于AndroidNativeApp与

在本文中,我们将详细介绍使用 InAppWebView 从内部存储加载 HTML 文件的各个方面,并为您提供关于app内嵌webview的相关解答,同时,我们也将为您带来关于Android Native App与WebView交互技巧_html/css_WEB-ITnose、Android Webview 加载外部html时选择加载本地的js,css等资源文件_html/css_WEB-ITnose、Android WebView从内部存储加载| Android 11 | Android R、android – 使用WebView加载本地.HTML文件的有用知识。

本文目录一览:

使用 InAppWebView 从内部存储加载 HTML 文件(app内嵌webview)

使用 InAppWebView 从内部存储加载 HTML 文件(app内嵌webview)

如何解决使用 InAppWebView 从内部存储加载 HTML 文件?

我将我的 html 文件存储在我的内部存储 /Download/..../index.html 中。这个 html 需要一个主机来加载它,所以我使用了 InAppLocalhostServer 的 InappWebview 功能,但出现错误

无法加载资源:file:///storage/emulated/0/Download/.../index.html

这是我的代码:

FutureBuilder(
                future: _futureGetPath,builder: (BuildContext context,AsyncSnapshot snapshot) {
                  if(snapshot.hasData) {
                    var dir = Directory(snapshot.data);
                    if (_permissionStatus) kontenPath = dir.path;
                    var file = File("$kontenPath/..../index.html");
                    return InAppWebView(
                      initialUrl: "http://localhost:8080/${file.uri}",initialOptions: InAppWebViewGroupOptions(
                        crossplatform: InAppWebViewOptions(),),onWebViewCreated: (controller) {},onLoadStart: (controller,url) {},onLoadStop: (controller,onLoadError: (controller,url,code,message) {
                        print("Error webview $message");
                      },);
                  } else {
                    return Center(child: vText("Loading..."),);
                  }
                },void _listenForPermissionStatus() async {
  final status = await Permission.storage.request().isGranted;
  setState(() {
    _permissionStatus = status;
  });
}

 Future<String> _getPath() {
return 
ExtStorage.getExternalStoragePublicDirectory(ExtStorage.DIRECTORY_DOWNLOADS);

}

我可以从内部存储加载带有 localhostserver 的 webview 吗?

解决方法

暂无找到可以解决该程序问题的有效方法,小编努力寻找整理中!

如果你已经找到好的解决方法,欢迎将解决方案带上本链接一起发送给小编。

小编邮箱:dio#foxmail.com (将#修改为@)

Android Native App与WebView交互技巧_html/css_WEB-ITnose

Android Native App与WebView交互技巧_html/css_WEB-ITnose

这次项目中有一个主页面完全是h5的页面,要求h5调用native,js交互传值,看起来貌似很简单,网上教程一大堆,但是在实际开发过程中还是遇到很多问题,在这里记录一下。

  1. 首先,设置user agent,使前端可区分请求来自APP ,这里我设置的是"android_app/1.0.0",名称加版本号,具体设置什么大家可随意。
WebSettings settings = webView.getSettings();String ua = settings.getUserAgentString();settings.setUserAgentString(ua + "; android_app/1.0.0");
登录后复制

2.H5页面的登录,因为我们的应用不需要登录也能浏览,H5的页面有些也是不需要登陆的,所以点击H5页面需要登录的地方,要跳转到Native的页面登录,登录成功刷新H5页面,设置cookie,使WebView页面保持登录状态,具体代码如下:注:WebSettings的一些设置一定要放到设置cookie前面执行。设置cookie要注意作用域的问题,以及setCookie的时候最好分步设置,大家可以看下面的代码,我setCookie()了四次,不要把所有字符串拼接起来再一次setCookie,一次setCookie可能只会设置成功第一个分号前的cookie值。

public void synCookies(Context context, String host, String cookies) { try { CookieSyncManager.createInstance(context); CookieManager cookieManager = CookieManager.getInstance(); // 5.0以上版本的webview做了较大的改动,如:同步cookie的操作已经可以自动同步、但前提是我们必须开启第三方cookie的支持。 // cookieManager.setAcceptThirdPartyCookies(webView, true);//5.0以下的手机崩溃 cookieManager.setAcceptCookie(true); cookieManager.removeSessionCookie();//移除 cookieManager.removeAllCookie(); //base64加密// String base64Cookies = Base64Utils.encodeStr(getCookies()); //根据RFC822规定,BASE64Encoder编码每76个字符,还需要加上一个回车换行。 //使用 commons-codec-1.10.jar 不会换行而且效率更高 //这里我使用的是sun.misc.BASE64Decoder.jar,每76个字符会换行,所以下面去掉换行,为什么不用上面的呢,使用commons-codec-1.10.jar,Android Studio编译提示方法重复,没找到解决办法。// base64Cookies = base64Cookies.replace("\n", "");// Log.i("base64Cookies:", base64Cookies); Calendar calendar = Calendar.getInstance(); calendar.add(Calendar.DAY_OF_MONTH, 7); String expiresTime = calendar.getTime().toGMTString(); Log.i("expiresTime =", expiresTime); //分开设置,不然只会设置第一个分号之前的cookie// cookieManager.setCookie(host, "Token=" + base64Cookies); //不加密 cookieManager.setCookie(host, "Token=" + cookies); //注意host的值,类似于这个网址:http://www.jianshu.com/writer#/notebooks/2498434/notes/4304102/preview,host可以取:www.jianshu.com或者.jianshu.com,注意作用域,不要把整个url都放上了。 cookieManager.setCookie(host, "Domain=" + host); cookieManager.setCookie(host, "Path=/"); // Expires变量是一个只写变量,它确定了Cookie有效终止日期。该属性值DATE必须以特定的格式来书写: // 星期几,DD-MM-YY HH:MM:SS GMT,GMT表示这是格林尼治时间。反之,不以这样的格式来书写,系统将无法识别。 // 该变量可省,如果缺省时,则Cookie的属性值不会保存在用户的硬盘中,而仅仅保存在内存当中,Cookie文件将随着浏览器的关闭而自动消失。 cookieManager.setCookie(host, "Expires=" + expiresTime); CookieSyncManager.getInstance().sync(); String newCookie = cookieManager.getCookie(host); if (newCookie != null) { Log.i("getCookie:", newCookie); } } catch (Exception e) { Log.e("failedCookie=%s", e.toString()); } }
登录后复制

3.自定义scheme、js交互传值、调用js方法及document对象

例如:登录scheme为 goto://just/loginref=http://www.baidu.com&callback=loginWeb webView.setWebViewClient(new WebViewClient() { @Override public boolean shouldOverrideUrlLoading(WebView view, String url) { //1.登录scheme url = goto://just/login?callback=loginWeb if (url.startsWith("goto://just/login")) { //登录,跳转到native得LoginActivity //成功后在onActivityResult()方法中执行js的回调方法loginWeb传toekn值给H5 return true; //2.跳转新activity scheme url = goto://just/newweb?ref=http://www.baidu.com } else if (url.startsWith("goto://just/newweb")) { //页面加载不在本页webview加载,而是新打开此MainActivity(标准模式,为了循环复用) String ref = "http://www.baidu.com"; Intent intent = new Intent(MainActivity.this, MainActivity.class); intent.putExtra("webUrl", ref); startActivity(intent); return true; } return super.shouldOverrideUrlLoading(view, url); } @Override public void onReceivedError(WebView view, WebResourceRequest request, WebResourceError error) { super.onReceivedError(view, request, error); //页面错误 llError.setVisibility(View.VISIBLE); } public void onPageFinished(WebView view, String url) { Log.d("WebView", "onPageFinished "); //获取整个页面的Html view.loadUrl("javascript:window.weixinObj.getHtml(''<head>''+" + "document.getElementsByTagName(''html'')[0].innerHTML+''</head>'');"); //通过document.title 获取页面的title view.loadUrl("javascript:window.weixinObj.getTitle(document.title)"); //此方法也可以通过document.title 获取标题,但是需要Api19才能使用// view.evaluateJavascript("document.title", new ValueCallback<String>() {// @Override// public void onReceiveValue(String title) {//// }// }); super.onPageFinished(view, url); } }); @Override protected void onActivityResult(int requestCode, int resultCode, Intent data) { super.onActivityResult(requestCode, resultCode, data); //登录页返回后执行 String callback = "loginWeb"; synCookies(this, host, cookies); webView.loadUrl("javascript:" + callback + "(''" + cookies + "'')"); webView.reload(); } private class InterfaceObject { @JavascriptInterface public void getHtml(String html) { //获取html的内容 } @JavascriptInterface public void getTitle(String title) { //获取标题 } }
登录后复制

4.以上是我在项目中使用到的一些交互,经过测试是可用的,其实上面写的这些网上有很多,但是比较分散,我就自己总结了一下,例子无法运行的(没有调试,可能有些逻辑错误),因为没有网页测试,如果使用本地html的也不好模拟网络上环境,所以只写了一些逻辑,需要大家自行写h5测试。

资源:Example下载

立即学习“前端免费学习笔记(深入)”;

Android Webview 加载外部html时选择加载本地的js,css等资源文件_html/css_WEB-ITnose

Android Webview 加载外部html时选择加载本地的js,css等资源文件_html/css_WEB-ITnose

在使用webview加载网页的时候,有一些固定的资源文件如js的jquery包,css,图片等资源会比较大,如果直接从网络加载会导致页面加载的比较慢,而且会消耗比较多的流量。所以这些文件应该放在assets里面同app打包。

要解决这个问题需要用到API 11(HONEYCOMB)提供的shouldInterceptRequest(WebView view, String url) 函数来加载本地资源。在API 21又将这个方法弃用了,是重载一个新的shouldInterceptRequest,需要的参数中将url替换成了成了request。

比如有一个图片icon.png,这个图片已经放在了assets中,现在加载了一个外部html,就需要直接把assets里面的图片拿出来加载而不需要重新从网络获取。当然可以在html里面将图片链接换成file:///android_asset/icon.png,但是这样这个html就不能在android ,ios,WAP中公用了。

实现代码:

立即学习“前端免费学习笔记(深入)”;

webView.setWebViewClient(new WebViewClient() {            @Override            public WebResourceResponse shouldInterceptRequest(WebView view, String url) {                WebResourceResponse response = null;                if (Build.VERSION.SDK_INT &gt;= Build.VERSION_CODES.HONEYCOMB){                    response = super.shouldInterceptRequest(view,url);                    if (url.contains("icon.png")){                        try {                            response = new WebResourceResponse("image/png","UTF-8",getAssets().open("icon.png"));                        } catch (IOException e) {                            e.printStackTrace();                        }                    }                }//                return super.shouldInterceptRequest(view, url);                return  response;            }            @TargetApi(Build.VERSION_CODES.LOLLIPOP)            @Override            public WebResourceResponse shouldInterceptRequest(WebView view, WebResourceRequest request) {                WebResourceResponse response = null;                response =  super.shouldInterceptRequest(view, request);                if (url.contains("icon.png")){                    try {                        response = new WebResourceResponse("image/png","UTF-8",getAssets().open("icon.png"));                    } catch (IOException e) {                        e.printStackTrace();                    }                }                return response;            }}
登录后复制


立即学习“前端免费学习笔记(深入)”;

Android WebView从内部存储加载| Android 11 | Android R

Android WebView从内部存储加载| Android 11 | Android R

找到答案,

在定位setAllowFileAccess时,必须从Build.VERSION_CODES.R显式地将其设置为true,否则将不允许您加载file:// URLs

所以解决方案是

webView.settings.allowFileAccess = true

在Java中,

webView.getSettings().setAllowFileAccess(true);

这在两种情况下都可以正常工作。

android – 使用WebView加载本地.HTML文件

android – 使用WebView加载本地.HTML文件

我已经阅读了很多关于如何使这项工作的描述,但它并没有在我的模拟器中,这真的令人沮丧.应该是小菜一碟!

我制作了一个超级简单的html文件:

<html>

    <head>
<h1> Hello </h1>

    </head>

    <body>
    </body>


</html>

然后我使用这个java代码来实现它:

package com.path.path;

import android.app.Activity;
import android.os.Bundle;
import android.webkit.WebView;



public class hello extends Activity {

WebView webView;

@Override
public void onCreate(Bundle savedInstanceState) {

    super.onCreate(savedInstanceState);
    setContentView(R.layout.hello);



     String url =  "file:///assets/hello.html";
    webView = (WebView) this.findViewById(R.id.char_view);
    webView.loadUrl(url);


}

}

当我在模拟器中加载此页面时,它表示该页面不可用.我错过了什么?

谢谢!

解决方法

将文件:///assets/hello.html更改为file:///android_asset/hello.html.这假设您的HTML文件位于项目中的assets / hello.html.

另外,移动你的< h1>元素进入< body>,以便它实际上可以工作.

今天关于使用 InAppWebView 从内部存储加载 HTML 文件app内嵌webview的介绍到此结束,谢谢您的阅读,有关Android Native App与WebView交互技巧_html/css_WEB-ITnose、Android Webview 加载外部html时选择加载本地的js,css等资源文件_html/css_WEB-ITnose、Android WebView从内部存储加载| Android 11 | Android R、android – 使用WebView加载本地.HTML文件等更多相关知识的信息可以在本站进行查询。

本文标签: