iis服务器助手广告广告
返回顶部
首页 > 资讯 > 移动开发 >Android WebView 上传文件支持全解析
  • 377
分享到

Android WebView 上传文件支持全解析

上传文件webviewAndroid 2022-06-06 08:06:51 377人浏览 独家记忆
摘要

默认情况下情况下,使用Android的WEBView是不能够支持上传文件的。而这个,也是在我们的前端工程师告知之后才了解的。因为Android的每个版本WebView的实现有差

默认情况下情况下,使用AndroidWEBView是不能够支持上传文件的。而这个,也是在我们的前端工程师告知之后才了解的。因为Android的每个版本WebView的实现有差异,因此需要对不同版本去适配。花了一点时间,参考别人的代码,这个问题已经解决,这里把我踩过的坑分享出来。
主要思路是重写WebChromeClient,然后在WebViewActivity中接收选择到的文件Uri,传给页面去上传就可以了。
创建一个WebViewActivity的内部类


public class XHSWebChromeClient extends WebChromeClient {
  // For Android 3.0+
  public void openFileChooser(ValueCallback<Uri> uploadMsg) {
    CLog.i("UPFILE", "in openFile Uri Callback");
    if (mUploadMessage != null) {
      mUploadMessage.onReceiveValue(null);
    }
    mUploadMessage = uploadMsg;
    Intent i = new Intent(Intent.ACTioN_GET_CONTENT);
    i.addCateGory(Intent.CATEGORY_OPENABLE);
    i.setType("**" : acceptType;
    i.setType(type);
    startActivityForResult(Intent.createChooser(i, "File Chooser"),
        FILECHOOSER_RESULTCODE);
  }
  // For Android 4.1
  public void openFileChooser(ValueCallback<Uri> uploadMsg, String acceptType, String capture) {
    CLog.i("UPFILE", "in openFile Uri Callback has accept Type" + acceptType + "has capture" + capture);
    if (mUploadMessage != null) {
      mUploadMessage.onReceiveValue(null);
    }
    mUploadMessage = uploadMsg;
    Intent i = new Intent(Intent.ACTION_GET_CONTENT);
    i.addCategory(Intent.CATEGORY_OPENABLE);
    String type = TextUtils.isEmpty(acceptType) ? "**");
    }
    startActivityForResult(Intent.createChooser(i, "File Chooser"), FILECHOOSER_RESULTCODE);
    return true;
  }
}

上面openFileChooser是系统未暴露的接口,因此不需要加Override的注解,同时不同版本有不同的参数,其中的参数,第一个ValueCallback用于我们在选择完文件后,接收文件回调到网页内处理,acceptType为接受的文件mime type。在Android 5.0之后,系统提供了onShowFileChooser来让我们实现选择文件的方法,仍然有ValueCallback,在FileChooserParams参数中,同样包括acceptType。我们可以根据acceptType,来打开系统的或者我们自己创建文件选择器。当然如果需要打开相机拍照,也可以自己去使用打开相机拍照的Intent去打开即可。
处理选择的文件
以上是打开响应的选择文件的界面,我们还需要处理接收到文件之后,传给网页来响应。因为我们前面是使用startActivityForResult来打开的选择页面,我们会在onActivityResult中接收到选择的结果。Show code:


@Override
protected void onActivityResult(int requestCode, int resultCode, Intent data) {
  super.onActivityResult(requestCode, resultCode, data);
  if (requestCode == FILECHOOSER_RESULTCODE) {
    if (null == mUploadMessage) return;
    Uri result = data == null || resultCode != RESULT_OK ? null : data.getData();
    if (result == null) {
      mUploadMessage.onReceiveValue(null);
      mUploadMessage = null;
      return;
    }
    CLog.i("UPFILE", "onActivityResult" + result.toString());
    String path = FileUtils.getPath(this, result);
    if (TextUtils.isEmpty(path)) {
      mUploadMessage.onReceiveValue(null);
      mUploadMessage = null;
      return;
    }
    Uri uri = Uri.fromFile(new File(path));
    CLog.i("UPFILE", "onActivityResult after parser uri:" + uri.toString());
    if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.LOLLIPOP) {
      mUploadMessage.onReceiveValue(new Uri[]{uri});
    } else {
      mUploadMessage.onReceiveValue(uri);
    }
    mUploadMessage = null;
  }
}

以上代码主要就是调用ValueCallback的onReceiveValue方法,将结果传回web。
注意,其他要说的,重要
由于不同版本的差别,Android 5.0以下的版本,ValueCallback 的onReceiveValue接收的参数类型是Uri, 5.0及以上版本接收的是Uri数组,在传值的时候需要注意。
选择文件会使用系统提供的组件或者其他支持的app,返回的uri有的直接是文件的url,有的是contentprovider的uri,因此我们需要统一处理一下,转成文件的uri,可参考以下代码(获取文件的路径)。
调用getPath可以将Uri转成真实文件的Path,然后可以自己生成文件的Uri


public class FileUtils {
  
  public static boolean isExternalStorageDocument(Uri uri) {
    return "com.android.externalstorage.documents".equals(uri.getAuthority());
  }
  
  public static boolean isDownloadsDocument(Uri uri) {
    return "com.android.providers.downloads.documents".equals(uri.getAuthority());
  }
  
  public static boolean isMediaDocument(Uri uri) {
    return "com.android.providers.media.documents".equals(uri.getAuthority());
  }
  
  public static String getDataColumn(Context context, Uri uri, String selection,
                    String[] selectionArgs) {
    Cursor cursor = null;
    final String column = "_data";
    final String[] projection = {
        column
    };
    try {
      cursor = context.getContentResolver().query(uri, projection, selection, selectionArgs,
          null);
      if (cursor != null && cursor.moveToFirst()) {
        final int column_index = cursor.getColumnIndexOrThrow(column);
        return cursor.getString(column_index);
      }
    } finally {
      if (cursor != null)
        cursor.close();
    }
    return null;
  }
  
  @SuppressLint("Newapi")
  public static String getPath(final Context context, final Uri uri) {
    final boolean isKitKat = Build.VERSION.SDK_INT >= Build.VERSION_CODES.KITKAT;
    // DocumentProvider
    if (isKitKat && DocumentsContract.isDocumentUri(context, uri)) {
      // ExternalStorageProvider
      if (isExternalStorageDocument(uri)) {
        final String docId = DocumentsContract.getDocumentId(uri);
        final String[] split = docId.split(":");
        final String type = split[0];
        if ("primary".equalsIgnoreCase(type)) {
          return Environment.getExternalStorageDirectory() + "/" + split[1];
        }
        // TODO handle non-primary volumes
      }
      // DownloadsProvider
      else if (isDownloadsDocument(uri)) {
        final String id = DocumentsContract.getDocumentId(uri);
        final Uri contentUri = ContentUris.withAppendedId(
            Uri.parse("content://downloads/public_downloads"), Long.valueOf(id));
        return getDataColumn(context, contentUri, null, null);
      }
      // MediaProvider
      else if (isMediaDocument(uri)) {
        final String docId = DocumentsContract.getDocumentId(uri);
        final String[] split = docId.split(":");
        final String type = split[0];
        Uri contentUri = null;
        if ("image".equals(type)) {
          contentUri = MediaStore.Images.Media.EXTERNAL_CONTENT_URI;
        } else if ("video".equals(type)) {
          contentUri = MediaStore.Video.Media.EXTERNAL_CONTENT_URI;
        } else if ("audio".equals(type)) {
          contentUri = MediaStore.Audio.Media.EXTERNAL_CONTENT_URI;
        }
        final String selection = "_id=?";
        final String[] selectionArgs = new String[] {
            split[1]
        };
        return getDataColumn(context, contentUri, selection, selectionArgs);
      }
    }
    // MediaStore (and general)
    else if ("content".equalsIgnoreCase(uri.getScheme())) {
      return getDataColumn(context, uri, null, null);
    }
    // File
    else if ("file".equalsIgnoreCase(uri.getScheme())) {
      return uri.getPath();
    }
    return null;
  }
}

再有,即使获取的结果为null,也要传给web,即直接调用mUploadMessage.onReceiveValue(null),否则网页会阻塞。
最后,在打release包的时候,因为我们会混淆,要特别设置不要混淆WebChromeClient子类里面的openFileChooser方法,由于不是继承的方法,所以默认会被混淆,然后就无法选择文件了。
就这样吧。
原文地址:Http://blog.isming.me/2015/12/21/android-webview-upload-file/

您可能感兴趣的文章:Android 解决WebView无法上传文件的问题Android中的webview支持页面中的文件上传实例代码Android WebView那些坑之上传文件示例浅谈关于Android WebView上传文件的解决方案


--结束END--

本文标题: Android WebView 上传文件支持全解析

本文链接: https://www.lsjlt.com/news/24812.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • Android 解决WebView无法上传文件的问题
    Android 解决WebView无法上传文件的问题Android原生的WebView并不支持上传文件,需要我们自己实现相应的方法。于是我把工作中的相关代码记录下来。下次直接拿来用就行了。一点一滴都是经验。 1。需要定义三个变量 priva...
    99+
    2023-05-30
    android webview roi
  • Android中怎么利用WebView上传文件
    今天就跟大家聊聊有关Android中怎么利用WebView上传文件,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。接收WebView打开文件选择器的通知收到通知后,打开文件选择器等待用...
    99+
    2023-05-30
    android webview
  • Discuz怎么支持大文件上传
    这篇文章给大家分享的是有关Discuz怎么支持大文件上传的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。5步轻松让 Discuz 支持500M大文件上传演示版本是 discuz-x3.4在使该插件前,请先确认Dis...
    99+
    2023-06-09
  • Android中如何使WebView支持HTML5 Video全屏播放
    这篇文章主要介绍Android中如何使WebView支持HTML5 Video全屏播放,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完! 1)需要在Andro...
    99+
    2024-04-02
  • Android项目中如何在webview页面中上传文件
    本篇文章为大家展示了Android项目中如何在webview页面中上传文件,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。Android webview在默认情况下是不支持网页中的文件上传功能的;如果...
    99+
    2023-05-31
    webview android roi
  • 全面解析SpringBoot文件上传功能
    这些天忙着刷题,又怕遗忘了spring boot, 所以抽出一点时间折腾折腾,加深点印象。 spring boot 的文件上传与 spring mvc 的文件上传基本一致,只需注意一些配置即可。 环境要求: Spring Boot v1.5...
    99+
    2023-05-30
    springboot 文件上传 bo
  • HTML5 File API是否支持文件拖放上传功能
    HTML5 File API是否支持文件拖放上传功能,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。新一代Web开发标准HTML 5可以带来...
    99+
    2024-04-02
  • vue上传文件formData上传的解决全流程
    目录vue上传文件formData上传解决axios实例的配置关键配置整体流程解决跨域上传文件跨域上传FormData格式等问题vue 批量上传文件简单说明一个实现思路vue上传文件...
    99+
    2024-04-02
  • 使用最小 WEB API 实现文件上传的Swagger支持
    目录前言:一、允许ContentType二、自定义OperationFilter前言: 上回,我们使用最小 WEB API 实现文件上传功能《​ ​使用最小 WEB API 实现文件...
    99+
    2024-04-02
  • input file上传文件样式支持html5的浏览器解决方法
    这篇文章将为大家详细讲解有关input file上传文件样式支持html5的浏览器解决方法,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。 ...
    99+
    2024-04-02
  • Java实现minio上传、下载、删除文件,支持https访问
    MinIO 是一款高性能、分布式的对象存储系统,Minio是基于Go语言编写的对象存储服务,适合于存储大容量非结构化的数据,例如图片、音频、视频、备份数据等,传统对象存储用例(例如辅助存储,灾难恢复和归档)方面表现出色。 一、配置 导入...
    99+
    2023-09-03
    java spring https Powered by 金山文档
  • 文件上传靶场-Nginx文件解析漏洞
    目录 1.靶场漏洞说明 2.漏洞利用过程 1.靶场漏洞说明 靶场地址:http://106.15.50.112:8020/ 一个简单的Nginx文件上传靶场,php配置中将cgi.fix_pathinfo设置为1,如果我们设置一个文件路径...
    99+
    2023-09-25
    php web安全 nginx 网络安全 学习
  • Apache支持shtml和include文件解析的方法
    今天小编给大家分享一下Apache支持shtml和include文件解析的方法的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有...
    99+
    2024-04-02
  • 如何使用Html5实现异步上传文件,支持跨域,带有上传进度条
    这篇文章主要为大家展示了“如何使用Html5实现异步上传文件,支持跨域,带有上传进度条”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“如何使用Html5实现异步上...
    99+
    2024-04-02
  • uniapp 发送全文件 支持App端ios、android,微信小程序,H5
    由于uniapp提供的API在app端只能上传图片和视频,不能上传其他文件,说以只能借助插件了。  ios端用的这个插件 获取到文件对象 免费的 ios-uniapp 文件选取word,pdf,xls等文件 - DCloud 插件市场uni...
    99+
    2023-09-03
    uni-app ios android
  • Android JetPack组件的支持库Databinding详解
    目录简介启用databinding布局xmlvariable (变量标签)data (数据标签)@{}表达式绑定普通数据绑定可观察数据对单个变量的绑定-fields对集合的绑定-co...
    99+
    2022-11-13
    Android JetPack组件Databinding JetPack组件 支持库 Databinding
  • 如何解决Android中WebView的input上传照片兼容问题
    小编给大家分享一下如何解决Android中WebView的input上传照片兼容问题,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!问题前几天接到的一个需求,是关于...
    99+
    2023-05-30
    android webview input
  • Web安全之文件上传漏洞详解
    一、文件上传漏洞定义 文件上传漏洞是指用户上传了一个可执行的脚本文件,并通过此脚本文件获得了执行服务器端命令的能力。这种攻击方式是最为直接和有效的,“文件上传”本身没有问题,有问题的是文件上传后,服务器怎么处理、解释文件。如果服务器的处理...
    99+
    2023-09-06
    web安全 网络安全 安全架构 网络攻击模型 安全威胁分析
  • 文件上传漏洞总结(全)
    文件上传漏洞 凡是存在上传文件的地方,都有可能存在文件上传漏洞,并不是说有文件上传就一定有文件上传漏洞。 原理 这主要看一些文件上传的代码有没有 严格限制用户上传的文件类型,比如,只可以上传.jpg|.png|.gif文件,但是由于代码不严...
    99+
    2023-10-06
    php 安全 web安全
  • PHP中的文件上传安全
    随着 Internet 的发展,文件上传功能已经成为了几乎所有 Web 应用程序的标准功能之一。在 PHP 中,文件上传功能是通过 $_FILES 超全局变量来实现的。然而,文件上传功能往往也是 Web 应用程序中最容易出现安全问题的地方。...
    99+
    2023-05-23
    PHP上传文件 文件安全 后端上传
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作