全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

浅谈关于Android WebView上传文件的解决方案

我们在开发需求的时候,难免会接入一下第三方的H5页面,有些H5页面是具有上传照片的功能,Android 中的 WebView是不能直接打开文件选择弹框的

接下来我讲简单提供一下解决方案,先说一下思路

1.接收WebView打开文件选择器的通知

2.收到通知后,打开文件选择器等待用户选择需要上传的文件

3.在onActivityResult中得到用户选择的文件的Uri

4.然后把Uri传递给Html5

这样就完成了一次H5选择文件的过程,下面我把代码贴出来自习看一下

首先,WebView必须要支持JS交互,所以要打开JS交互

mWebView.getSettings().setJavaScriptEnabled(true);

当H5在调用上传文件的Api的时候,WebView会回调 openFileChooser和onShowFileChooser 方法来通知我们,我们这个时候要做的就是重写这个方法

需要注意的是这个方法在不同的Api上会回调不同行参方法

mWebView.setWebChromeClient(new WebChromeClient() {


   @Override
   public void onProgressChanged(WebView view, int newProgress) {
    if (newProgress == 100) {
     mBar.setVisibility(View.GONE);
    } else {
     mBar.setVisibility(View.VISIBLE);
     mBar.setProgress(newProgress);
    }
    super.onProgressChanged(view, newProgress);
   }

   //For Android API < 11 (3.0 OS)
   public void openFileChooser(ValueCallback<Uri> valueCallback) {
    uploadMessage = valueCallback;
    openImageChooserActivity();
   }

   //For Android API >= 11 (3.0 OS)
   public void openFileChooser(ValueCallback<Uri> valueCallback, String acceptType, String capture) {
    uploadMessage = valueCallback;
    openImageChooserActivity();
   }

   //For Android API >= 21 (5.0 OS)
   @Override
   public boolean onShowFileChooser(WebView webView, ValueCallback<Uri[]> filePathCallback, WebChromeClient.FileChooserParams fileChooserParams) {
    uploadMessageAboveL = filePathCallback;
    openImageChooserActivity();
    return true;
   }

  }); 

我们在openFileChooser方法中先保存了一下ValueCallback的回调对象,这个对象最后用来通知H5文件地址,我们之后在调用openFileChooser方法来打开文件选择器

private void openImageChooserActivity() {
  Intent i = new Intent(Intent.ACTION_GET_CONTENT);
  i.addCategory(Intent.CATEGORY_OPENABLE);
  i.setType("image/*");
  startActivityForResult(Intent.createChooser(i, "Image Chooser"), FILE_CHOOSER_RESULT_CODE);
 } 

当用户选择完文件后,会调用onActivityResult方法,我们重写并等待回调

@Override
 protected void onActivityResult(int requestCode, int resultCode, Intent data) {
  super.onActivityResult(requestCode, resultCode, data);
  if (requestCode == FILE_CHOOSER_RESULT_CODE) {
   if (null == uploadMessage && null == uploadMessageAboveL) return;
   Uri result = data == null || resultCode != RESULT_OK ? null : data.getData();
   if (uploadMessageAboveL != null) {
    onActivityResultAboveL(requestCode, resultCode, data);
   } else if (uploadMessage != null) {
    uploadMessage.onReceiveValue(result);
    uploadMessage = null;
   }
  }
 }

 @TargetApi(Build.VERSION_CODES.LOLLIPOP)
 private void onActivityResultAboveL(int requestCode, int resultCode, Intent intent) {
  if (requestCode != FILE_CHOOSER_RESULT_CODE || uploadMessageAboveL == null)
   return;
  Uri[] results = null;
  if (resultCode == Activity.RESULT_OK) {
   if (intent != null) {
    String dataString = intent.getDataString();
    ClipData clipData = intent.getClipData();
    if (clipData != null) {
     results = new Uri[clipData.getItemCount()];
     for (int i = 0; i < clipData.getItemCount(); i++) {
      ClipData.Item item = clipData.getItemAt(i);
      results[i] = item.getUri();
     }
    }
    if (dataString != null)
     results = new Uri[]{Uri.parse(dataString)};
   }
  }
  uploadMessageAboveL.onReceiveValue(results);
  uploadMessageAboveL = null;
 } 

onActivityResult就是用来通知H5用户选择的文件地址,在这个方法里,用我们之前保存的ValueCallback对象,调用onReceiveValue方法,H5就可以收到我们传递给它的地址信息了!

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。


# Android  # WebView上传文件  # 上传文件  # Android 解决WebView无法上传文件的问题  # Android中的webview支持页面中的文件上传实例代码  # Android WebView那些坑之上传文件示例  # Android WebView 上传文件支持全解析  # 回调  # 重写  # 选择器  # 方法来  # 的是  # 在这个  # 我把  # 要做  # 这个时候  # 看一下  # 第三方  # 用我  # 贴出  # 需要注意  # 先说  # 上会  # 大家多多  # 就可以  # 我讲 


相关文章: 如何破解联通资金短缺导致的基站建设难题?  如何在Golang中实现微服务服务拆分_Golang微服务拆分与接口管理方法  广州营销型建站服务商推荐:技术优势与SEO优化解析  C++中引用和指针有什么区别?(代码说明)  ,巨量百应是干嘛的?  如何快速生成凡客建站的专业级图册?  XML的“混合内容”是什么 怎么用DTD或XSD定义  相册网站制作软件,图片上的网址怎么复制?  上海网站制作网站建设公司,建筑电工证网上查询系统入口?  佛山网站制作系统,佛山企业变更地址网上办理步骤?  建站IDE高效指南:快速搭建+SEO优化+自适应模板全解析  如何快速生成高效建站系统源代码?  如何在Windows虚拟主机上快速搭建网站?  如何快速完成中国万网建站详细流程?  国美网站制作流程,国美电器蒸汽鍋怎么用官方网站?  厦门模型网站设计制作公司,厦门航空飞机模型掉色怎么办?  平台云上自主建站:模板化设计与智能工具打造高效网站  网站制作中优化长尾关键字挖掘的技巧,建一个视频网站需要多少钱?  如何在西部数码注册域名并快速搭建网站?  如何在宝塔面板中创建新站点?  音乐网站服务器如何优化API响应速度?  定制建站流程步骤详解:一站式方案设计与开发指南  建站主机选哪家性价比最高?  湖州网站制作公司有哪些,浙江中蓝新能源公司官网?  高端智能建站公司优选:品牌定制与SEO优化一站式服务  建站主机如何选?性能与价格怎样平衡?  怎么制作网站设计模板图片,有电商商品详情页面的免费模板素材网站推荐吗?  如何通过虚拟主机快速搭建个人网站?  关于BootStrap modal 在IOS9中不能弹出的解决方法(IOS 9 bootstrap modal ios 9 noticework)  网站设计制作企业有哪些,抖音官网主页怎么设置?  公司网站设计制作厂家,怎么创建自己的一个网站?  免费网站制作appp,免费制作app哪个平台好?  如何用PHP工具快速搭建高效网站?  如何在云主机上快速搭建网站?  TestNG的testng.xml配置文件怎么写  家庭服务器如何搭建个人网站?  红河网站制作公司,红河事业单位身份证如何上传?  天河区网站制作公司,广州天河区如何办理身份证?需要什么资料有预约的网站吗?  重庆市网站制作公司,重庆招聘网站哪个好?  如何在新浪SAE免费搭建个人博客?  武清网站制作公司,天津武清个人营业执照注销查询系统网站?  公司网站的制作公司,企业网站制作基本流程有哪些?  建站之星伪静态规则如何正确配置?  深圳网站制作平台,深圳市做网站好的公司有哪些?  完全自定义免费建站平台:主题模板在线生成一站式服务  如何快速选择适合个人网站的云服务器配置?  SAX解析器是什么,它与DOM在处理大型XML文件时有何不同?  广东企业建站网站优化与SEO营销核心策略指南  建站VPS推荐:2025年高性能服务器配置指南  常州企业建站如何选择最佳模板? 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。