android系统webview最新版本_webview加载h5页面空白

android系统webview最新版本_webview加载h5页面空白做android聊天时,遇到过一个问题,h5的页面发送的图片在android端不能响应,ios那边一路畅通。也是相当无奈,目前发现了好多android端与ios端webView的异同。android端与ios确的不同大致包括:1:android不能直接打开html的下载文件,需要先下载保存本地在打开本地文件2:android不能直接打开pdf文件,同样要下载再打开3:如题,h5页面的发送图片按钮点…

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

做android聊天时,遇到过一个问题,h5的页面发送的图片在android端不能响应,ios那边一路畅通。也是相当无奈,目前发现了好多android端与ios端webView的异同。

android端与ios确的不同大致包括:

1:android不能直接打开html的下载文件,需要先下载保存本地在打开本地文件

2:android不能直接打开pdf文件,同样要下载再打开

3:如题,h5页面的发送图片按钮点击没反应,ios却可以

4:android可以postUrl,ios不行,需要js混合开发

下面简单说下第三点。

1:出现的原因:

H5 访问本地文件的时候,使用的 ,WebView 出于安全性的考虑,限制了以上操作

2:解决方法

重写 WebviewChromeClient 中的 openFileChooser() 和 onShowFileChooser()方法响应,然后使用原生代码来实现调用本地相册和拍照的功能,最后在 onActiivtyResult 把选择的图片 URI 回传给 WebviewChromeClient。

3:大致步骤

1.弹出对话框选择相机或相册

2.调用系统相册的实现代码

3.调用系统相机拍照的实现代码

4.需要兼容 6.0 的动态权限问题和 7.0 的文件管理问题。

5.相机拍照后的图片上传后要进行删除,以免占用手机存储空间

chatWebView.setWebChromeClient(new WebChromeClient() {

@Override

public boolean onShowFileChooser(WebView webView, ValueCallback filePathCallback, FileChooserParams fileChooserParams) {

Log.d(“ChatFragment”, “filePathCallback>>>>>” + filePathCallback);

mUploadCallbackAboveL = filePathCallback;

uploadPicture();

return true;

}

//For Android >= 4.1

public void openFileChooser(ValueCallback valueCallback, String acceptType, String capture) {

mUploadMessage = valueCallback;

//调用系统相机或者相册

uploadPicture();

}

}

);

upload()方法是打开打开相册等系列操作,常规操作就省略了,其中两个参数mUploadMessage和mUploadCallbackAboveL是用来处理获取图片等文件的Uri之后传递给Js操作的。之后再onActivityResult()方法里处理结果

@Override

public void onActivityResult(int requestCode, int resultCode, Intent data) {

super.onActivityResult(requestCode, resultCode, data);

switch (requestCode) {

case CHOOSE_PHOTO:

if (resultCode == RESULT_OK) {

Uri uri = data.getData();

if (uri != null) {

uploadImage(uri);

}

} else{

uploadImage(null);

}

break;

case TAKE_PHOTO:

if (resultCode == RESULT_OK) {

Uri uri = Uri.fromFile(mTmpFile);

if (uri != null) {

uploadImage(uri);

}

}else{

uploadImage(null);

}

break;

default:

break;

}

}

private void uploadImage(Uri uri) {

if (mUploadMessage != null) {

mUploadMessage.onReceiveValue(uri);

mUploadMessage = null;

}

if (mUploadCallbackAboveL != null) {

if(uri!=null){

mUploadCallbackAboveL.onReceiveValue(new Uri[]{uri});

}else{

mUploadCallbackAboveL.onReceiveValue(null);

}

mUploadCallbackAboveL = null;

}

}

upLoadImage(Uri uri)方法是将图片传递给JS,之后的逻辑交给Js处理。注意取消选择文件操作的时候同样要调该方法,但是参数传null.

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/190619.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 虚拟机体验NAS私人云全揭秘:深度揭秘虚拟机安装群晖DSM6.2/6.2.1/6.2.2/6.2.3系统洗白全过程(附赠洗白码)

    虚拟机体验NAS私人云全揭秘:深度揭秘虚拟机安装群晖DSM6.2/6.2.1/6.2.2/6.2.3系统洗白全过程(附赠洗白码)文章目录DIY群晖、半洗白以及全洗白的区别获得群晖序列号SN和Mac地址mac1对PE启动群晖虚拟机洗白虚拟机中的DIY群晖6.2系统群晖虚拟机洗白后的效果展示DIY群晖、半洗白以及全洗白的区别1、DIY群晖就是号称的黑群晖,不能转码、无QuickConnect远程网络服务:(1)不能注册和登录QuickConnect(简称QC,就是没有公网的用户利用群晖服务器进行内网穿透);(2)DS…

    2022年4月28日
    67
  • spssχ2检验_一致性检验和配对卡方检验的SPSS实例操作图文详解[通俗易懂]

    spssχ2检验_一致性检验和配对卡方检验的SPSS实例操作图文详解[通俗易懂]一致性检验和配对卡方检验的SPSS实例操作图文详解,配对计数资料的卡方检验。一、问题与数据有两种方法可用于诊断某种癌症,A方法简单易行,成本低,患者更容易接受,B方法结果可靠,但操作繁琐,患者配合困难。某研究选择了53例待诊断的门诊患者,每个患者分别用A和B两种方法进行诊断(表1),判断两种方法诊断癌症有无差别,A方法是否可以代替B方法。表1进口药和国产药治疗效果二、对数据结构的分析之前介绍过成…

    2022年5月17日
    40
  • shell语法基础_实现shell

    shell语法基础_实现shellLinux操作系统Shell编程快速入门、shell变量、、运算符、条件判断、流程控制(if、case、for、while语句)。

    2022年9月13日
    0
  • netty通信框架_王国风云2控制台代码

    netty通信框架_王国风云2控制台代码写在前面所属章节链接第二章2.1BIO通信aaaTimeServer代码importjava.io.IOException;importjava.net.ServerSocket;importjava.net.Socket;publicclassTimeServer{ publicstaticvoidmain(String[]args)throwsIOException{ intport=8081; if(args

    2022年10月2日
    0
  • golang 最新激活码(JetBrains全家桶)

    (golang 最新激活码)这是一篇idea技术相关文章,由全栈君为大家提供,主要知识点是关于2021JetBrains全家桶永久激活码的内容IntelliJ2021最新激活注册码,破解教程可免费永久激活,亲测有效,下面是详细链接哦~https://javaforall.net/100143.html0BXA05X8YC-eyJsa…

    2022年3月30日
    281
  • Redis版本5.0.5安装

    这篇文章主要讲解Redis安装,以后的文章我会对Redis做一个详细介绍,已经Redis应用。1.解压压缩包tar-zxvfredis-5.05.tar.gz2.安装gccyuminstallgcc检查gcc安装是否成功rpm-qa|grepgcc3.进入文件夹make安装cdredis-5.0.5makeMALLOC=libc4.后台运行redissrc/redis-server&检查redis服务启动情况..

    2022年4月8日
    39

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号