微信小程序:实现证件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...

相关推荐
开发者小天20 小时前
在Ant Design Vue 中使用图片预览的插件
前端·javascript·vue.js·前端框架
华科云商xiao徐20 小时前
手把手教你用Go打造带可视化的网络爬虫
前端·爬虫
_月下闲人20 小时前
已掌握 Vue2 的开发者,快速上手 Vue3
前端·javascript·vue.js
光头程序员20 小时前
vite_react 插件 find_code 最终版本
前端·javascript·react.js
陈随易20 小时前
改变世界的编程语言MoonBit:项目文件详解
前端·后端·程序员
拜无忧20 小时前
three.js纸飞机飞行撞建筑
前端·three.js
无光末阳20 小时前
前端 vue3+router 比较好用的自定义日志插件
前端·vue.js
liercats20 小时前
ECharts图表正常但动画不显示?问题排查指南:大概率是宽高问题
前端
四季豆豆豆20 小时前
办公任务分发项目 laravel vue mysql 第一章:核心功能构建 API
vue.js·mysql·laravel
摸鱼的鱼lv20 小时前
sonarQube全流程实战:从VSCode开发到CI/CD质量门禁
前端