中软高科鸿蒙Next身份证读卡SDK集成说明

news2025/1/19 9:11:19

导入har

项目中导入提供的开发包 readcardlibrary.har

鸿蒙next的NFC使用配置,请参考官方文档。

需要在EntryAbility 中添加NFC tag相关的监听。

在项目的 module.json5 文件中需要配置NFC的权限

"requestPermissions": [
      {
        "name": "ohos.permission.NFC_TAG",
        "reason": "$string:app_name"
      },
      {
        "name": "ohos.permission.NFC",
        "reason": "$string:app_name"
      },
      {
        "name": "ohos.permission.INTERNET",
        "reason": "$string:app_name"
      },
      {
        "name": "ohos.permission.STORE_PERSISTENT_DATA",
        "reason": "$string:app_name"
      }
    ]

还需要配置NFC的tag类型

"skills": [
          {
            "entities": [
              "entity.system.home"
            ],
            "actions": [
              "action.system.home",
              // add the nfc tag action
              "ohos.nfc.tag.action.TAG_FOUND"
            ],
            "uris": [
              {
                "type":"tag-tech/NfcA"
              },
              {
                "type":"tag-tech/IsoDep"
              },
              {
                "type":"tag-tech/NfcB"
              }
              // Add other technology if neccessary,
              // such as: NfcB/NfcF/NfcV/Ndef/MifareClassic/MifareUL/NdefFormatable
            ]
          }
        ]

在需要NFC读卡的界面使用SDK

// 读卡库
import { ReadCardManager, IdCardData } from 'readcardlibrary'
// NFC相关
import { tag, nfcController } from '@kit.ConnectivityKit';
// 状态码
let StatusCode = ReadCardManager.getInstance().StatusCodeEnum()

设置读卡参数

// 设置参数
ReadCardManager.getInstance().readSetting({
            decodeImageType: "dn1", // dn0: 无照片   dn1: 平台解码照片
            readCardType: 2, // 2:NFC
            saveLog: false, // 是否保存日志文件
            openLocalCache: true, // 是否开启本地缓存
            ipPortArray: [{
              // 云解码服务器配置。
              address: 'yfs4.sfzydq.com',
              port: 9999,
              canUse: true
            }]
          })

// 设置APPID
// 配置读卡 appid (正式商业APPID请联系我司商务分配)
ReadCardManager.getInstance().setAppId("");

接收到NFC TAG 开始读卡

/**
   * 接收到NFC TAG,开始读卡
   * @param tagInfo
   */
  tagNfc(tagInfo: tag.TagInfo): void {
    try {
      console.log("canIUse NFC.Tag : " + canIUse("SystemCapability.Communication.NFC.Tag"));
      if (tagInfo == null || tagInfo == undefined) {
        console.log("no TagInfo to be created, ignore it.");
        return;
      }
      if (tagInfo.technology == null || tagInfo.technology == undefined) {
        console.log("technology is null");
        return;
      }
      let that = this;
      ReadCardManager.getInstance()
        .startReadCard(tagInfo, (code: number, msg: string, value: Object, cardType: number) => {
          let code_msg = "code:" + code + "\n" + "msg:" + msg;
          console.log("\n" + code_msg);
          switch (code) {
            case StatusCode.ININ_ING.code: // 初始化中
              break;
            case StatusCode.ININ_OK.code: // 初始化成功
              that.showToast('初始化成功,请刷身份证');
              break;
            case StatusCode.ININ_FAILE.code: // 初始化失败
              that.showToast('初始化失败');
              break;
            case StatusCode.FIND_CARD_START.code: // 开始寻卡
              break;
            case StatusCode.FIND_CARD_SUCCESS.code: // 寻卡成功
              break;
            case StatusCode.READCARD_START.code: // 开始解码 请勿移动卡片
              that.loadingController.open();
              break;
            case StatusCode.READCARD_SUCCESS.code: // 解码成功
              that.loadingController.close();
              switch (cardType) {
                case StatusCode.CARD_IC.code: // IC卡
                  console.log("IC卡:", value);
                  that.message = "IC卡:" + value as string;
                  break;
                case StatusCode.CARD_IDCARD.code: // 身份证
                  // 读取到的身份证信息
                  // 详细字段说明,详见文档下发的附录
                  let data = value as IdCardData;
                  let cardInfoStr = "";
                  switch (data.type) {
                    case StatusCode.CARD_IDCARD_CHINA.code:
                      cardInfoStr = '\n姓名: ' + data.name +
                        '\n性别: ' + data.sex +
                        '\n民族: ' + data.nation +
                        '\n生日: ' + data.birthday +
                        '\n住址: ' + data.address +
                        '\n证件号码: ' + data.id +
                        '\n签发机关: ' + data.issue +
                        '\n有效期限: ' + data.startDate + '-' + data.endDate;
                      that.message = "中国居民身份证:" + cardInfoStr;
                      break;
                    case StatusCode.CARD_IDCARD_GAT.code:
                      cardInfoStr = '\n姓名: ' + data.name +
                        '\n性别: ' + data.sex +
                        '\n生日: ' + data.birthday +
                        '\n住址: ' + data.address +
                        '\n证件号码: ' + data.id +
                        '\n签发机关: ' + data.issue +
                        '\n有效期限: ' + data.startDate + '-' + data.endDate;
                      that.message = "港澳台居住证:" + cardInfoStr;
                      break;
                    case StatusCode.CARD_IDCARD_FOREIGN.code:
                    case StatusCode.CARD_IDCARD_FOREIGN_OLD.code:
                      cardInfoStr = '\n中文姓名: ' + data.nameChinese +
                        '\n英文姓名: ' + data.nameEnglish +
                        '\n性别: ' + data.sex +
                        '\n生日: ' + data.birthday +
                        '\n国籍: ' + data.nationlity +
                        '\n证件号码: ' + data.id +
                        '\n有效期限: ' + data.startDate + '-' + data.endDate;
                      that.message = "外国永久居住证:" + cardInfoStr;
                      break;
                  }
                  // 当设置平台解码身份证照片时,
                  // idCardInfo.imageBase64字段,为base64编码的照片字符串,可直接用于显示
                  that.headImage = data.imageBase64;
                  break;
              }
              break;
            case StatusCode.READCARD_FAILE.code: // 解码失败
              that.headImage = "";
              that.loadingController.close();
              that.showToast('解码失败');
              that.message = "解码失败:" + msg;
              break;
          }
        })
    } catch (error) {
      console.log("tag.getTagInfo catched error: " + error);
    }
  }
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2278861.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

编写Wireshark的Lua脚本详解及示例解析

编写Wireshark的Lua脚本详解及示例解析 编写Wireshark Lua脚本的基本步骤SMGP.lua脚本解析脚本解析要点总结Wireshark是一个强大的网络协议分析工具,支持通过Lua脚本扩展其功能,以解析自定义或复杂的协议。下面将详细介绍如何编写Wireshark的Lua脚本,并通过解析一个具体的SM…

【20】Word:小许-质量管理-论文❗

目录 题目​ NO1.2.3.4.5 NO6.7 NO8 NO9 NO10.11 题目 NO1.2.3.4.5 另存为“Word.docx”文件在考生文件夹下,F12Fn是另存为的作用布局→页面设置对话框→纸张:大小A4→页边距:上下左右不连续ctrl选择除表格外的所有内容→开始→字体对…

【软件开发过程管理规范】需求管理,需求分析,设计开发管理,测试管理(Word)

一、需求管理规程 1 简介 2 过程总体描述 2.1 过程概述 2.2 过程流程图 3 过程元素描述 3.1 准备阶段 3.2 需求调研 3.3 需求分析 软件开发人员及用户往往容易忽略信息沟通,这导致软件开发出来后不能很好地满足用户的需要,从而造成返工。而返工不仅在技术…

RabbitMQ-消息可靠性以及延迟消息

目录 消息丢失 一、发送者的可靠性 1.1 生产者重试机制 1.2 生产者确认机制 1.3 实现生产者确认 (1)开启生产者确认 (2)定义ReturnCallback (3)定义ConfirmCallback 二、MQ的持久化 2.1 数据持久…

了解 .mgJSON 文件

.mgJSON (Motion Graphics JSON)是一个基于标准 JSON 格式的文件扩展名,专门用于存储和交换与动态图形、动画和多媒体应用相关的数据。该格式支持静态和动态数据流,能够精确描述动画、物体变换、图形效果等。 .mgJSON 文件通过层级…

小白爬虫——selenium入门超详细教程

目录 一、selenium简介 二、环境安装 2.1、安装Selenium 2.2、浏览器驱动安装 三、基本操作 3.1、对页面进行操作 3.1.1、初始化webdriver 3.1.2、打开网页 3.1.3、页面操作 3.1.4、页面数据提取 3.1.5、关闭页面 ?3.1.6、综合小案例 3.2、对页面元素进行操作 3…

pycharm+pyside6+desinger实现查询汉字笔顺GIF动图

一、引言 这学期儿子语文期末考试有一道这样的题目: 这道题答案是B,儿子做错了选了C。我告诉他“车字旁”和“车”的笔顺是不一样的,因为二者有一个笔画是不一样的,“车字旁”下边那笔是“提”,而“车”字是“横”&am…

快手极速版如何查找ip归属地?怎么关掉

在数字化时代,个人隐私的保护成为了广大用户关注的焦点。快手极速版作为一款备受欢迎的短视频应用,其IP归属地的显示与关闭功能自然也成了用户热议的话题。本文将详细介绍如何在快手极速版中查找IP归属地以及如何关闭IP属地显示,帮助用户更好…

C++ 模拟真人鼠标轨迹算法 - 防止游戏检测

一.简介 鼠标轨迹算法是一种模拟人类鼠标操作的程序,它能够模拟出自然而真实的鼠标移动路径。 鼠标轨迹算法的底层实现采用C/C语言,原因在于C/C提供了高性能的执行能力和直接访问操作系统底层资源的能力。 鼠标轨迹算法具有以下优势: 模拟…

Go语言strings包与字符串操作:从基础到高级的全面解析

Go语言strings包与字符串操作:从基础到高级的全面解析 引言 Go语言以其简洁、高效和强大的标准库而闻名,其中strings包是处理字符串操作的核心工具。本文将深入探讨Go语言中strings包的功能及其在实际开发中的应用,帮助开发者更好地理解和使用这一工具。 1. strings包概述…

基于YOLOv4与Tkinter的口罩识别系统

往期精彩 基于YOLOv11的番茄成熟度实时检测系统设计与实现 用YOLOv11检测美国手语:挥动手腕的科技魔法 基于YOLOv11模型PyQt的实时鸡行为检测系统研究 OpenCV与YOLO在人脸识别中的应用研究(论文源码) 计算机视觉:农作物病虫害检测系统:基于Y…

电力场景红外测温图像绝缘套管分割数据集labelme格式2436张1类别

数据集格式:labelme格式(不包含mask文件,仅仅包含jpg图片和对应的json文件) 图片数量(jpg文件个数):2436 标注数量(json文件个数):2436 标注类别数:1 标注类别名称:["arrester"] 每个类别标注的框数&am…

AI编程工具使用技巧——通义灵码

活动介绍通义灵码1. 理解通义灵码的基本概念示例代码生成 2. 使用明确的描述示例代码生成 3. 巧妙使用注释示例代码生成 4. 注意迭代与反馈原始代码反馈后生成优化代码 5. 结合生成的代码进行调试示例测试代码 其他功能定期优化生成的代码合作与分享结合其他工具 总结 活动介绍…

电梯系统的UML文档05

Dispatcher 不控制实际的电梯组件,但它在软件系统中是重要的。每一个电梯有一个ispatcher,主要功能是计算电梯的移动方向、移动目的地以及保持门的打开时间。它和系统中除灯控制器以外的几乎所有控制对象交互。 安全装置也是一个环境对象,它…

各种获取数据接口

各种获取数据免费接口 1.音频接口 代理配置 /music-api:{target:https://api.cenguigui.cn/,changeOrigin:true,rewrite:(path)>path.replace(/^\/music-api/,),secure:false}axios全局配置 import axios from axios;const MusicClient axios.create({baseURL: /music-a…

外包公司名单一览表(成都)

大家好,我是苍何。 之前写了一篇武汉的外包公司名单,评论区做了个简单统计,很多人说,在外包的日子很煎熬,不再想去了。 有小伙伴留言说有些外包会强制离职,不行就转岗,让人极度没有安全感。 这…

第十一章 图论

#include <iostream> #include <cstdio> #include <vector>using namespace std;const int MAXN 1000;vector<int> graph[MAXN]; //用向量存储邻接表中的每个点及其连接的的其他点int main(){return 0; } #include <iostream> #include &…

大数据中 TopK 问题的常用套路

大数据中 TopK 问题的常用套路 作者 Chunel Feng&#xff0c;编程爱好者&#xff0c;阿里巴巴搜索引擎开发工程师。开源项目&#xff1a;Caiss 智能相似搜索引擎 对于海量数据到处理经常会涉及到 topK 问题。在设计数据结构和算法的时候&#xff0c;主要需要考虑的应该是当前算…

RabbitMQ基础篇

文章目录 1 RabbitMQ概述1.1 消息队列1.2 RabbitMQ体系结构 2 RabbitMQ工作模式2.1 简单模式&#xff08;Simple Queue&#xff09;2.2 工作队列模式&#xff08;Work Queues&#xff09;2.3 发布/订阅模式&#xff08;Publish/Subscribe&#xff09;2.4 路由模式&#xff08;R…

【人工智能】:搭建本地AI服务——Ollama、LobeChat和Go语言的全方位实践指南

前言 随着自然语言处理&#xff08;NLP&#xff09;技术的快速发展&#xff0c;越来越多的企业和个人开发者寻求在本地环境中运行大型语言模型&#xff08;LLM&#xff09;&#xff0c;以确保数据隐私和提高响应速度。Ollama 作为一个强大的本地运行框架&#xff0c;支持多种先…