在本文中,我们将详细介绍使用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)
- 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 文件?
我将我的 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
这次项目中有一个主页面完全是h5的页面,要求h5调用native,js交互传值,看起来貌似很简单,网上教程一大堆,但是在实际开发过程中还是遇到很多问题,在这里记录一下。
- 首先,设置user agent,使前端可区分请求来自APP ,这里我设置的是"android_app/1.0.0",名称加版本号,具体设置什么大家可随意。
2.H5页面的登录,因为我们的应用不需要登录也能浏览,H5的页面有些也是不需要登陆的,所以点击H5页面需要登录的地方,要跳转到Native的页面登录,登录成功刷新H5页面,设置cookie,使WebView页面保持登录状态,具体代码如下:注:WebSettings的一些设置一定要放到设置cookie前面执行。设置cookie要注意作用域的问题,以及setCookie的时候最好分步设置,大家可以看下面的代码,我setCookie()了四次,不要把所有字符串拼接起来再一次setCookie,一次setCookie可能只会设置成功第一个分号前的cookie值。
3.自定义scheme、js交互传值、调用js方法及document对象
4.以上是我在项目中使用到的一些交互,经过测试是可用的,其实上面写的这些网上有很多,但是比较分散,我就自己总结了一下,例子无法运行的(没有调试,可能有些逻辑错误),因为没有网页测试,如果使用本地html的也不好模拟网络上环境,所以只写了一些逻辑,需要大家自行写h5测试。
资源:Example下载
立即学习“前端免费学习笔记(深入)”;
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 >= 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
找到答案,
在定位setAllowFileAccess时,必须从Build.VERSION_CODES.R显式地将其设置为true
,否则将不允许您加载file:// URLs
。
所以解决方案是
webView.settings.allowFileAccess = true
在Java中,
webView.getSettings().setAllowFileAccess(true);
这在两种情况下都可以正常工作。
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); }
}
当我在模拟器中加载此页面时,它表示该页面不可用.我错过了什么?
谢谢!
解决方法
另外,移动你的< 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文件等更多相关知识的信息可以在本站进行查询。
本文标签: