H5调用本地相册/相机上传图片

本文详细记录了H5如何调用Android的本地相册和相机功能进行图片上传的过程,包括H5中使用标签、Android端WebView的配置与监听,以及在Android 7.0以上版本的适配和文件选择后的处理。同时提到了选择图片后可能出现的只调用一次的问题,以及使用Luban库进行图片压缩的步骤。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

在开发中有时候会用到H5调用本地图片或者相机,像第三方的实名认证,在线客服等等都需要上传图片。H5中只需要通过<input>调用即可,ios是可以的实现的,不需要自己处理,除非客户端压缩图片,但是Android中需要自己处理,比较坑,本文记录H5调用本地图片或者相机的实现过程以及遇到的问题。

先看效果图

H5

H5主要是通过input标签来获取图片

 <input class="upload-input"  accept="image/*" multiple required type="file" @change="chooseImg">

Android

通过WebView加载h5页面,监听WebView对应的方法,实现自己的逻辑。

WebView初始化,放开对应的权限

private fun initWebView() {
        val settings = mWebView.settings
        settings.javaScriptEnabled = true
        settings.javaScriptCanOpenWindowsAutomatically = true
        //自适应屏幕
        settings.layoutAlgorithm = SINGLE_COLUMN
        settings.loadWithOverviewMode = true
        settings.domStorageEnabled = true
        settings.databaseEnabled = true
        settings.setSupportZoom(false)
        mWebView.isHorizontalScrollBarEnabled = false
        mWebView.isVerticalScrollBarEnabled = false
        mWebView.webViewClient = webViewClient
        mWebView.webChromeClient = webViewChromeClient
}

设置WebChromeClient

当点击input标签的时候会调用WebChromeClientonShowFileChooser()方法(5.0+)或者openFileChooser()

在uniApp中,如果你想要H5页面通过调用用户的本地相册选择图片上传到服务器,可以按照以下步骤操作: 1. 首先,引入必要的权限管理,确保应用有访问用户照片的权限。在`app.json`文件中添加对`scope.writePhotosAlbum`权限的申请: ```json { "permission": { "scope.writePhotosAlbum": { "desc": "用于获取您的照片" } } } ``` 2. 使用uni-app提供的API `getUserMedia`请求相机相册权限: ```javascript uni.requestPermission({ permission: 'scope.writePhotosAlbum', success(res) { if (res.granted) { // 用户同意了权限,可以选择图片 getUserMedia({ type: 'image', success(result) { let file = result.tempFilePath; // 获取选中的图片路径 // 进行上传处理 uploadImage(file); }, fail(err) { console.error('获取图片失败', err); } }); } else { console.log('用户拒绝了权限'); } }, fail() { console.log('请求权限失败'); } }); ``` 3. 定义`uploadImage`函数,这里假设你已经有了一个HTTP上传接口: ```javascript async function uploadImage(imgPath) { const formData = new FormData(); formData.append('file', uni.uploader.filepond.convertFile(imgPath)); try { await axios.post('/api/upload', formData, {headers: {'Content-Type': 'multipart/form-data'}}); uni.showToast({message: '图片上传成功'}); } catch (error) { uni.showToast({message: '图片上传失败', errorDescription: error.message}); } } ``` 4. 考虑使用uni-app的`uni.uploader`组件配合`filepond`插件来进行更复杂的图片预览、裁剪等操作。 记得在实际项目中检查网络连接以及错误处理,以便提供良好的用户体验。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值