当前位置: 首页 > wzjs >正文

win7和wordpress博客seo怎么做

win7和wordpress,博客seo怎么做,wordpress安装模板文件,wordpress tags页面UniApp 多端人脸认证图片上传实现(H5 非 H5) 本文简洁说明如何用 UniApp 实现跨端(H5、小程序、App)人脸认证图片的拍摄、处理与上传,核心是兼容不同平台的差异点。 核心功能与流程 调用前置摄像头拍摄人脸照片图片压…

UniApp 多端人脸认证图片上传实现(H5 + 非 H5)

本文简洁说明如何用 UniApp 实现跨端(H5、小程序、App)人脸认证图片的拍摄、处理与上传,核心是兼容不同平台的差异点。

核心功能与流程
  1. 调用前置摄像头拍摄人脸照片
  2. 图片压缩处理(H5 端需额外处理,非 H5 端直接使用原生能力)
  3. 上传至后端接口进行认证
  4. 根据认证结果执行后续操作
关键差异点说明

在这里插入图片描述

chooseImagefile(params) {let that = this;// 调用前置摄像头拍摄(限制1张,仅相机拍摄)uni.chooseImage({count: 1,sourceType: ["camera"],camera: "front",success: (resFile) => {const tempFilePath = resFile.tempFilePaths[0];// #ifdef H5// H5端:图片压缩+格式处理const canvas = document.createElement("canvas");const ctx = canvas.getContext("2d");// 获取图片信息(尺寸等)uni.getImageInfo({src: tempFilePath,success: (imageInfo) => {const originalWidth = imageInfo.width;const originalHeight = imageInfo.height;// 按比例调整尺寸(限制最大1080px,最小640px)let targetWidth = originalWidth;let targetHeight = originalHeight;const MAX_WIDTH = 1080;const MIN_WIDTH = 640;if (targetWidth > MAX_WIDTH) {targetHeight = Math.round((MAX_WIDTH / targetWidth) * targetHeight);targetWidth = MAX_WIDTH;} else if (targetWidth < MIN_WIDTH) {targetHeight = Math.round((MIN_WIDTH / targetWidth) * targetHeight);targetWidth = MIN_WIDTH;}// 设置canvas尺寸并绘制图片canvas.width = targetWidth;canvas.height = targetHeight;const img = new Image();img.crossOrigin = "anonymous"; // 解决跨域img.src = tempFilePath;img.onload = () => {ctx.drawImage(img, 0, 0, targetWidth, targetHeight);// 转为base64并压缩(质量0.8)const compressedBase64 = canvas.toDataURL("image/jpeg", 0.8);// base64转Blob再转Fileconst blob = this.dataURLtoBlob(compressedBase64);const file = new File([blob], `face_${Date.now()}.jpg`, { type: "image/jpeg" });// H5用fetch上传(不支持uni.uploadFile传File)const formData = new FormData();formData.append("file", file);formData.append("name", params.name);formData.append("idCard", params.idCard);uni.showLoading({ title: "认证中...", mask: true });fetch(`${HTTP_REQUEST_URL}/api/v1/auth/faceAuth`, {method: "POST",headers: { Authorization: that.token },body: formData}).then(res => res.json()).then(data => {uni.hideLoading();if (data.code === 200 && data.data.auth) {params.faceUrl = data.data.faceUrl;that.handleSave(params); // 认证成功,执行保存} else {uni.showToast({ title: "人脸认证失败,请重新拍摄", icon: "none" });}}).catch(err => {uni.hideLoading();uni.showToast({ title: "上传失败,请重试", icon: "none" });console.error("H5上传失败:", err);});};},fail: err => {uni.showToast({ title: "获取图片信息失败", icon: "none" });console.error("getImageInfo失败:", err);}});// #endif// #ifndef H5// 非H5端(小程序/App)直接上传uni.showLoading({ title: "认证中...", mask: true });uni.uploadFile({url: `${HTTP_REQUEST_URL}/api/v1/auth/faceAuth`,filePath: tempFilePath, // 直接用本地文件路径name: "file",formData: { name: params.name, idCard: params.idCard },header: { "Content-Type": "multipart/form-data", [TOKENNAME]: that.token },success: res => {uni.hideLoading();try {const data = JSON.parse(res.data);if (data.code === 200 && data.data.auth) {params.faceUrl = data.data.faceUrl;that.handleSave(); // 认证成功,执行保存} else {uni.showToast({ title: "人脸认证失败,请重新拍摄", icon: "none" });}} catch (e) {uni.showToast({ title: "数据解析失败", icon: "none" });}},fail: err => {uni.hideLoading();uni.showToast({ title: "上传失败,请重试", icon: "none" });console.error("上传失败:", err);}});// #endif},fail: err => {uni.showToast({ title: "拍照失败", icon: "none" });console.error("拍照失败:", err);}});
},// 辅助方法:base64转Blob(H5端用)
dataURLtoBlob(dataurl) {const arr = dataurl.split(',');const mime = arr[0].match(/:(.*?);/)[1];const bstr = atob(arr[1]);let n = bstr.length;const u8arr = new Uint8Array(n);while (n--) {u8arr[n] = bstr.charCodeAt(n);}return new Blob([u8arr], { type: mime });
}
使用说明
  1. 代码通过#ifdef H5和#ifndef H5区分平台逻辑,无需额外修改
  2. 需确保HTTP_REQUEST_URL(后端接口地址)、TOKENNAME(令牌键名)已定义
  3. handleSave方法为认证成功后的后续操作,需根据业务实现
  4. dataURLtoBlob是 H5 端必须的辅助方法,用于 base64 转文件格式

文章转载自:

http://7sp8DagP.smnxr.cn
http://Kl3tvlN7.smnxr.cn
http://dSQesYba.smnxr.cn
http://xFtA607V.smnxr.cn
http://z1SzZkQv.smnxr.cn
http://60ji7j3n.smnxr.cn
http://EoGPRTzM.smnxr.cn
http://1wAckCOQ.smnxr.cn
http://VRCGLkAm.smnxr.cn
http://UuJgdoDC.smnxr.cn
http://eKJmyeDQ.smnxr.cn
http://69K1G5Mq.smnxr.cn
http://vJfiQGp0.smnxr.cn
http://SspzKtdj.smnxr.cn
http://lvcKt9Sz.smnxr.cn
http://ReCkr7fC.smnxr.cn
http://5UdaWicT.smnxr.cn
http://78hSpWro.smnxr.cn
http://RKR1oDCs.smnxr.cn
http://jt0uTtUj.smnxr.cn
http://tCiX8fL3.smnxr.cn
http://5FNpnVJh.smnxr.cn
http://zNHaGGaD.smnxr.cn
http://njC7bOSX.smnxr.cn
http://J3G7rvez.smnxr.cn
http://TaLTCs5k.smnxr.cn
http://67VkRaF1.smnxr.cn
http://6E62Kqyb.smnxr.cn
http://Z5vjSdL3.smnxr.cn
http://2UJeN3AP.smnxr.cn
http://www.dtcms.com/wzjs/678330.html

相关文章:

  • 平凉市住房和城乡建设局网站扬中网站建设包括哪些
  • 外贸建站哪家公司好seo网站的锚文本怎么写
  • 安徽建设厅网站施网站建设源代码共享
  • 学做网站需要多久时间购物网站每个模块主要功能
  • 做旅游网站的目的是什么备案 手机网站
  • 站长之家网站建设制作西安市建设工程
  • 网站开发工作经验怎么写html网页搭建
  • 广州管网建设小江seo
  • 下载站推广正规网站建设报价
  • 衡水淘宝的网站建设杭州滨江网站建设公司
  • seo网站优化方建设公司网站征集信息的通知
  • 免费制作网站的基本流程辽宁网络科技有限公司
  • 怎么办个人网站室内装饰设计平面图
  • 四平网站建设在线咨询广州市网站公司
  • 福州微信网站开发wordpress 分类目录 文章
  • 网站建设讲话二级建造师报名的官网
  • 网站地图怎么做XML做电影网站要怎么样的主机
  • 中山 网站设计wordpress 树 插件
  • 即墨网站开发做网站和做app的区别
  • go语言做网站品牌设计师工资一般多少
  • 建设的访问网站需要密码课程的网站建设
  • 网上做设计兼职哪个网站好点河北网诚网站建设
  • 网站的公司wordpress管理页面密码忘记
  • 网站如何建设推广南宁高新区建设房产局网站
  • 常州市城市建设局网站课程网站开发背景和意义
  • 番禺区移动端网站制作琼中网站建设
  • 制作好的网站百度怎么推广产品
  • 郑州做网站报价站域名多少钱行情软件免费下载的网站
  • 竞价网站服务器网站建设行内资讯
  • 如何用云服务器做网站系统开发的需求分析阶段的重要工作之一是