html5plus请求打开相机权限,iOS与H5交互 询问相机、相册权限的问题

当H5页面需要打开手机相机和相册但用户拒绝权限后,通过原生代码处理权限并传递图片给H5。文章介绍了如何将图片转换为字符串,确保base64编码选项正确,并在OC中调用JS方法将图片数据传给H5。
摘要由CSDN通过智能技术生成

问题背景:

某个H5页面中需要打开手机本地相册及照相机,用户选择某几张图片之后上传至服务器上。纯H5完成的话,当打开相机或者相册时,第一次会正常询问权限,但是如果用户点击了不允许之后,询问弹窗不再能弹出,H5处理不了。

当然简单粗暴地方式就是改为纯原生来写,不过我们的页面已用了很久,只是新增了一个上传的功能,所以还是延续当前页面,只不过改为原生和H5交互的方式,即e页面仍是H5页面,打开相册相机的弹窗改为由原生代码处理,最后将用户选择到的图片传给H5,由H5将数据传给服务端。

中间的交互不再赘述,网上到处都是,只是最后将拿到的数据传给H5这一步有一个小小的坑需注意;

第一步,将图片转化成字符串:

//当我们拿到图片之后,会将图片image转化成字符串

NSString *imageStr = [self encodeImageToBase64:image];

//将上述合法的字符串传给H5

[self p_toJSPramaWithImageBase64Str:imageStr];

此处,压缩转化中,base64EncodedStringWithOptions的options必须传NSDataBase64EncodingEndLineWithCarriageReturn,否则会失败!!!

// 将image转成5兆以内的二进制流,然后转化成base64的字符串

// #define ImageMaxLength 1024.0*1024.0*5 //5M

- (NSString *)encodeImageTo

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值