网站首页 > 博客文章 正文
为节省开发时间,最近用h5做了一个上传凭证的页面,通过android studio 打包成apk,本来通过框架的组件能方便的实现上传功能,因为开始没有使用dcloud,apicloud,懒得做较大改动,直接想法修改h5页面实现上传功能。h5本身是很方便的,但是做好的h5的上传功能通过手机浏览器,电脑浏览器都是正常的,但是打包成apk后,input type="file" 点击就没有任何反应了。搞了好久,才解决了这个问题。
直接来代码吧
android studio 3.6 ,
先上h5:
这个上传在浏览器中是好的,打包apk后不反应。
<div class="frambox">
<h2>以下信息无需填写</h2>
<div class="list_box">
<div class="m-cell demo-small-pitch">
<div class="cell-item">
<div class="cell-left">单号</div>
<div class="cell-right">
<input type="text" class="cell-input" readonly=readonly value="{$orderdetail.order_sn}"
autocomplete="off">
</div>
</div>
<div class="cell-item">
<div class="cell-left">拍出人</div>
<div class="cell-right">
<input type="text" class="cell-input" readonly=readonly value="{$orderdetail.netpoint}"
autocomplete="off">
</div>
</div>
<div class="cell-item">
<div class="cell-left">价值</div>
<div class="cell-right">
<input type="text" class="cell-input" readonly=readonly value="{$orderdetail.amount}"
autocomplete="off">
</div>
</div>
<div class="cell-item">
<div class="cell-left">说明</div>
<div class="cell-right">
<input type="text" class="cell-input" placeholder="点击此处可填写" value=""
autocomplete="off">
</div>
</div>
</div>
</div>
</div>
<div class="frambox">
<h2>上传支付凭证(二选一)</h2>
<div class="font_box">
<div class="m-grids-2">
<a href="javascript:sfzzmSc();" class="grids-item">
<div id="sfzzmImg" class="grids-icon">
<img src="images/shenfenzheng-a.png">
</div>
<div class="grids-txt">
<span>上传支付凭证1</span>
</div>
</a> <input style="display: none" id="sfzzm" type="file"
onchange="javascript:showpic(this,'sfzzmImg');" accept="image/*" multiple />
<a href="javascript:sfzfmSc();" class="grids-item">
<div id="sfzfmImg" class="grids-icon">
<img src="images/shenfenz-b.png">
</div>
<div class="grids-txt">
<span>上传支付凭证2</span>
</div>
</a> <input style="display: none" id="sfzfm" type="file"
onchange="javascript:showpic(this,'sfzfmImg');" accept="image/*" multiple />
</div>
</div>
</div>
<div class="btn_mian">
<a href="javascript:next();" class="btn btn-primary btnbom">确认买入</a>
</div>
安卓代码:
package com.tonglianandroid.xinlingshoushop;
import android.annotation.SuppressLint;
import android.annotation.TargetApi;
import android.app.Activity;
import android.content.ClipData;
import android.content.Intent;
import android.net.Uri;
import android.os.Build;
import android.os.Bundle;
import android.webkit.ValueCallback;
import android.webkit.WebChromeClient;
import android.webkit.WebSettings;
import android.webkit.WebView;
import androidx.appcompat.app.AppCompatActivity;
import com.tongliananroid.xinlingshoushop.R;
public class MainActivity extends AppCompatActivity {
private ValueCallback<Uri> uploadMessage;
private ValueCallback<Uri[]> uploadMessageAboveL;
private final static int FILE_CHOOSER_RESULT_CODE = 10000;
@SuppressLint("SetJavaScriptEnabled")
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
WebView webview = (WebView) findViewById(R.id.web);
WebSettings settings = webview.getSettings();
settings.setUseWideViewPort(true);
settings.setLoadWithOverviewMode(true);
settings.setJavaScriptEnabled(true);
// 1.设置WebChromeClient,重写文件上传回调
webview.setWebChromeClient(new WebChromeClient() {
// For Android < 3.0
public void openFileChooser(ValueCallback<Uri> valueCallback) {
uploadMessage = valueCallback;
openImageChooserActivity();
}
// For Android >= 3.0
public void openFileChooser(ValueCallback valueCallback, String acceptType) {
uploadMessage = valueCallback;
openImageChooserActivity();
}
//For Android >= 4.1
public void openFileChooser(ValueCallback<Uri> valueCallback, String acceptType, String capture) {
uploadMessage = valueCallback;
openImageChooserActivity();
}
// For Android >= 5.0
@Override
public boolean onShowFileChooser(WebView webView, ValueCallback<Uri[]> filePathCallback, WebChromeClient.FileChooserParams fileChooserParams) {
uploadMessageAboveL = filePathCallback;
openImageChooserActivity();
return true;
}
});
//加载本地网页
String targetUrl = "https://www.1235.com/game_center/";
webview.loadUrl(targetUrl);
}
// 2.回调方法触发本地选择文件
private void openImageChooserActivity() {
Intent i = new Intent(Intent.ACTION_GET_CONTENT);
i.addCategory(Intent.CATEGORY_OPENABLE);
// i.setType("image/*");//图片上传
// i.setType("file/*");//文件上传
i.setType("*/*");//文件上传
startActivityForResult(Intent.createChooser(i, "Image Chooser"), FILE_CHOOSER_RESULT_CODE);
}
// 3.选择图片后处理
@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();
// 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;
}
} else {
//这里uploadMessage跟uploadMessageAboveL在不同系统版本下分别持有了
//WebView对象,在用户取消文件选择器的情况下,需给onReceiveValue传null返回值
//否则WebView在未收到返回值的情况下,无法进行任何操作,文件选择器会失效
if (uploadMessage != null) {
uploadMessage.onReceiveValue(null);
uploadMessage = null;
} else if (uploadMessageAboveL != null) {
uploadMessageAboveL.onReceiveValue(null);
uploadMessageAboveL = null;
}
}
}
// 4. 选择内容回调到Html页面
@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;
}
}
效果:
代码简单easy!
猜你喜欢
- 2025-02-03 6 plus不能用? 如何让iPhone拍出好照片
- 2025-02-03 几款经典好用的Android手机拍照软件推荐
- 2025-02-03 今日应用:这个应用只允许你自拍(允许应用使用我的相机 不能选)
- 2025-02-03 今起,全国推行!申领程序快来看→
- 2025-02-03 “电子驾驶证”今起在全国全面推广,申领指南来了
- 2025-02-03 想用手机拍出神级照片,你可能要学会这几招
- 2025-02-03 当心!安卓系统曝漏洞!有人可能正在用你的手机秘密拍照
- 2025-02-03 「德州提醒」安卓系统曝漏洞!有人可能正用你的手机秘密拍照……
- 2025-02-03 “电子驾驶证”已在全国全面推广,申领指南来了!
- 2025-02-03 电子证件照怎么导入手机,看完这篇不信你还学不会!
你 发表评论:
欢迎- 368℃用AI Agent治理微服务的复杂性问题|QCon
- 367℃手把手教程「JavaWeb」优雅的SpringMvc+Mybatis整合之路
- 359℃初次使用IntelliJ IDEA新建Maven项目
- 352℃Maven技术方案最全手册(mavena)
- 348℃安利Touch Bar 专属应用,让闲置的Touch Bar活跃起来!
- 347℃InfoQ 2024 年趋势报告:架构篇(infoq+2024+年趋势报告:架构篇分析)
- 345℃IntelliJ IDEA 2018版本和2022版本创建 Maven 项目对比
- 343℃从头搭建 IntelliJ IDEA 环境(intellij idea建包)
- 最近发表
- 标签列表
-
- powershellfor (55)
- messagesource (56)
- aspose.pdf破解版 (56)
- promise.race (63)
- 2019cad序列号和密钥激活码 (62)
- window.performance (66)
- qt删除文件夹 (72)
- mysqlcaching_sha2_password (64)
- ubuntu升级gcc (58)
- nacos启动失败 (64)
- ssh-add (70)
- jwt漏洞 (58)
- macos14下载 (58)
- yarnnode (62)
- abstractqueuedsynchronizer (64)
- source~/.bashrc没有那个文件或目录 (65)
- springboot整合activiti工作流 (70)
- jmeter插件下载 (61)
- 抓包分析 (60)
- idea创建mavenweb项目 (65)
- vue回到顶部 (57)
- qcombobox样式表 (68)
- vue数组concat (56)
- tomcatundertow (58)
- pastemac (61)
本文暂时没有评论,来添加一个吧(●'◡'●)