Android webview加载本地图片

转载 2015年07月07日 17:14:24

出于安全的考虑,一般情况下webview并不允许网页读取和操作网页文件所在文件夹外的文件。

在网上搜索后,发现有3种可行的方法:

1、使用WebView自身的资源拦截与回调来实现该功能;
WebView的shouldInterceptRequest回调从API 11才开始引入,所以使用该方法不能兼容2.2与2.3的系统;

2、img的src使用base64的编码格式,这种方法会造成html文件较大,轻量的网页可以考虑使用;

3、img的src使用content协议,通过ContentProvider来进行提供相应资源; 

方法2和方法3都可以兼容2.x的系统


方法3的例子:

[java] view plaincopy在CODE上查看代码片派生到我的代码片
  1. com.packagename.provider;  
  2. public class MyProvider extends ContentProvider {   
  3.      @Override  
  4.      public ParcelFileDescriptor openFile(Uri uri, String mode){  
  5.         URI fileURI = URI.create( "file://" + uri.getPath() );  
  6.         File file = new File( fileURI );  
  7.   
  8.         ParcelFileDescriptor parcel = null;  
  9.         try {  
  10.             parcel = ParcelFileDescriptor.open(file, ParcelFileDescriptor.MODE_READ_ONLY);  
  11.         } catch (FileNotFoundException e) {  
  12.             Log.e( TAG, "Error finding: " + fileURI + "\n" + e.toString() );  
  13.         }  
  14.   
  15.         return parcel;  

AndroidManifest.xml

[html] view plaincopy在CODE上查看代码片派生到我的代码片
  1. <provider  
  2.        android:name=".provider.MyProvider"  
  3.        android:authorities="com.packagename" />  

You can then access your files which would normally be

<code style="margin: 0px; padding: 0px; border: 0px; vertical-align: baseline; font-family: Consolas, Menlo, Monaco, 'Lucida Console', 'Liberation Mono', 'DejaVu Sans Mono', 'Bitstream Vera Sans Mono', 'Courier New', monospace, serif;"><span class="pln" style="margin: 0px; padding: 0px; border: 0px; vertical-align: baseline; background-color: transparent;"> file</span><span class="pun" style="margin: 0px; padding: 0px; border: 0px; vertical-align: baseline; background-color: transparent;">:</span><span class="com" style="margin: 0px; padding: 0px; border: 0px; vertical-align: baseline; color: gray; background-color: transparent;">//sdcard/Android/data/com.packagename/image.jpg</span></code>

by using

<code style="margin: 0px; padding: 0px; border: 0px; vertical-align: baseline; font-family: Consolas, Menlo, Monaco, 'Lucida Console', 'Liberation Mono', 'DejaVu Sans Mono', 'Bitstream Vera Sans Mono', 'Courier New', monospace, serif;"><span class="pln" style="margin: 0px; padding: 0px; border: 0px; vertical-align: baseline; background-color: transparent;"> content</span><span class="pun" style="margin: 0px; padding: 0px; border: 0px; vertical-align: baseline; background-color: transparent;">:</span><span class="com" style="margin: 0px; padding: 0px; border: 0px; vertical-align: baseline; color: gray; background-color: transparent;">//com.packagename/sdcard/Android/data/com.packagename/image.jpg</span></code>

So essentially replace file:// with content://com.packagename


http://stackoverflow.com/questions/11303118/android-set-a-local-image-to-an-img-element-in-webview

相关文章推荐

webview中的img标签加载Android本地的图片

很好的在移动端嵌入了Hmtl页面,并且通过Android代码将本地图片赋给了html页面中的img标签...

Android使用WebView加载本地图片终极大杀招

WebView 主要调用三个方法:loadUrl、loadData、loadDataWithBaseURL。1、loadUrl 直接加载网页、图片并显示。(本地或是网络上的网页、图片、g...

Webview打开本地图片文件选择解决方案

Webview打开本地图片选择器解决方案Webview打开本地图片选择器十分之麻烦,其在安卓系统3x 4x 5x上的行为都不同,处理也不同,所以之前差点崩溃。经过测试和完善,最终其在各个版本上都能完美...
  • zhtsuc
  • zhtsuc
  • 2015年10月15日 16:20
  • 15033

Android使用WebView从相册/拍照中添加图片

解决这个问题花了很长时间搜索了解,网上大部分使用openFileChooser但都没解决一个存在的问题。就是当弹出选择图片/相机框之后,取消选择,就再也不能点击选择按钮了。这篇文章是为了记录这一点,为...
  • DJCKEN
  • DJCKEN
  • 2015年06月05日 17:50
  • 21180

android WebView加载html 并 引用本地资源(图片、字体库)

本文介绍如何用android WebView加载html代码,并在html内引用apk里的资源文件,例如图片、字体库等。 先说一般情况,文件夹有html、ttf字库、图片 html代码如下...

WebView控件替换方案

引用地址:http://www.cnblogs.com/ct2011/p/4100132.html 为什么放弃WebView Android WebView做普通浏览还好,...

Webview打开本地图片文件选择解决方案

Webview打开本地图片选择器解决方案Webview打开本地图片选择器十分之麻烦,其在安卓系统3x 4x 5x上的行为都不同,处理也不同,所以之前差点崩溃。经过测试和完善,最终其在各个版本上都能完美...
  • zhtsuc
  • zhtsuc
  • 2015年10月15日 16:20
  • 15033

Android中WebView加载Html中的图片添加点击事件

基本的思路: (1)WebView来加载HTML。 (2)向HTML中注入JavaScript,利用JavaScript来调用Android中的方法(执行一些跳转的操作等等)。  首先你必须有一...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:Android webview加载本地图片
举报原因:
原因补充:

(最多只允许输入30个字)