微信小程序:实现证件OCR识别

公司要求在小程序证件上传时,自动识别证件(身份证、户口本)等,自动填入表单中,达到提升用户体验。

方案

解决此问题,有几种方案:

方案 识别率 成本
公司部署OCR模型,调后端接口
纯前端OCR方案
百度证件OCR识别服务 -

三种方案中,我们综合考虑,百度提供的接口服务最好的方案,因为正确率高,响应速度快,成本根据用户的量关联的。所有第三种方案可行。 大家也可以使用其他厂商的API服务~

实现思路:

获取百度云的baidu_access_token ---> 用户在小程序端选择图片--->图片转换base64 --->请求百度云OCR服务

代码实现

获取百度云的baidu_access_token

js 复制代码
/**
 * 使用 AK,SK 生成鉴权签名(Access Token)
 * @return string 鉴权签名信息(Access Token)
 */
export default function getAccessToken() {
  let options = {
    method: "POST",
    url:
      "https://aip.baidubce.com/oauth/2.0/token?grant_type=client_credentials&client_id=" +
      AK +
      "&client_secret=" +
      SK,
  };
  return new Promise((resolve, reject) => {
    request(options)
      .then((res) => {
        console.log(res, "获取token成功");
        uni.setStorageSync("baidu_access_token", res.access_token);
      })
      .catch((error) => {
        console.log(error, "获取token失败");
        uni.showToast({
          title: "获取token失败",
          icon: "none",
        });
        reject(error);
      });
  });
}

用户在小程序端选择图片

使用uniapp 或 微信小程序的选择相册接口,也可以使用uview的upload组件。我这里使用的是upload组件

js 复制代码
  <u-upload :fileList="fileList1" @afterRead="(e) => afterRead(e)">
  </u-upload>

图片转换base64

js 复制代码
// 转换为base64的函数
function toBase64(path) {
  return new Promise((resolve, reject) => {
    uni.request({
      url: path,
      responseType: "arraybuffer",
      success: (res) => {
        resolve(uni.arrayBufferToBase64(res.data));
      },
    });
  });
}

请求百度云OCR服务

js 复制代码
export default function cardOCR(imageUrl) {
  const access_token = uni.getStorageSync("baidu_access_token");
  const options = {
    method: "POST",
    url: `https://aip.baidubce.com/rest/2.0/ocr/v1/idcard?access_token=${access_token}`,
    headers: {
      "Content-Type": "application/x-www-form-urlencoded",
    },
    data: {
      id_card_side: "front",
    },
  };
  options.headers["Access-Token"] = access_token;

  return new Promise((resolve, reject) => {
    toBase64(imageUrl).then((res) => {
      options.data.image = res;
      request(options)
        .then((res) => {
          if (res.words_result_num > 0) {
            resolve(res.words_result);
          }
        })
        .catch((error) => {
          reject(error);
        });
    });
  });
}

结语

友好推荐:闪图浏览器插件,作者开发的插件;解决写文章没有表情包使用,如何保存,管理表情包的烦恼; juejin.cn/post/751636...

相关推荐
tager3 小时前
🔥3行代码搞定全局代理!告别插件依赖的极简方案
前端·fiddler·charles
gnip4 小时前
axios 拦截器实现用户无感刷新 access_token
前端
程序员码歌4 小时前
【零代码AI编程实战】AI灯塔导航-成果展示篇
前端·ai编程·cursor
gnip4 小时前
前端实现即时通讯,常用的技术
前端
烛阴5 小时前
告别 any!用联合类型打造更灵活、更安全的 TS 代码
前端·typescript
excel6 小时前
全面解析 JavaScript 类继承:方式、优缺点与应用场景
前端
用户21411832636026 小时前
dify案例分享-100% 识别率!发票、汇票、信用证全搞定的通用票据识别工作流
前端
拾光拾趣录7 小时前
基础 | HTML语义、CSS3新特性、浏览器存储、this、防抖节流、重绘回流、date排序、calc
前端·面试
小小小小宇8 小时前
前端监测用户卡顿之INP
前端
小小小小宇8 小时前
监测用户在浏览界面过程中的卡顿
前端