前言

小编前面几期文章分别给大家介绍了使用 HMS ML Kit SDK 实现微笑抓拍、证件照 DIY、拍照翻译的功能开发(链接见文章末尾),本次小编给大家带来的是使用 HMS 机器学习服务(ML Kit)银行卡识别 SDK,一键实现银行卡识别与绑定功能。

银行卡识别的应用场景

介绍开发步骤前,我们先来谈谈银行卡识别的具体应用场景,银行 APP、移动支付、缴费类 APP、电商类 APP 或者其它带支付功能的 APP 在使用过程中往往会遇到如下常见的几个应用场景:

  • 绑卡支付
    常用于支付类APP,或者带支付功能的APP,用来绑定信用卡、银联借记卡,提供在线支付功能
  • 转账汇款
    常用于银行或者支付类APP,用来给本行或者他行用户进行转账。
  • 实名认证、身份审核
    比如社交类APP,通过银行卡关联的身份信息完成快速的实名认证、身份审核等操作。

不管是绑卡、转账汇款还是身份审核,涉及到银行卡操作的都会遇到一个关键的步骤,录入银行卡信息,如银行卡号、有效期等;由于银行卡号码往往较长,手工录入很容易出错,而且手工录入卡号信息,操作繁琐,使用体验不佳;借助 HMS ML Kit 银行卡专用识别能力,则可以轻松应对以上场景,快速、精准的录入银行卡信息,改善用户使用体验。

如何使用华为银行卡识别服务

银行卡识别服务可以将银行卡信息通过视频流方式输入,得到图像中银行卡的卡号、有效期等重要文本信息。该服务配合身份证识别,可以为用户提供实名认证、身份审核、卡号录入等实用功能,降低输入成本,为用户提供更加友好的操作体验。

银行卡识别提供处理插件。开发者可以集成银行卡识别插件,无需实现相机视频流数据的处理,从而实现银行卡识别能力的快速集成。

集成银行卡识别服务关键流程

由于华为提供了银行卡识别插件,开发者可以直接调用银行卡插件,因此开发步骤更加简单了,仅仅需要拉起界面获取结果就可以完成卡号的识别。

开发实战

1 开发准备

1.1 在项目级 gradle 里添加华为 maven 仓

打开 AndroidStudio 项目级 build.gradle 文件,增量添加如下 maven 地址:

  1. buildscript {
  2. repositories {
  3. maven {url 'http://developer.huawei.com/repo/'}
  4. }
  5. }
  6. allprojects {
  7. repositories {
  8. maven { url 'http://developer.huawei.com/repo/'}
  9. }
  10. }

1.2 在应用级的 build.gradle 里面加上 SDK 依赖

  1. dependencies {
  2. // 引入基础SDK
  3. implementation 'com.huawei.hms:ml-computer-vision-bcr:1.0.3.303'
  4. // 引入银行卡识别plugin包
  5. implementation 'com.huawei.hms:ml-computer-card-bcr-plugin:1.0.3.300'
  6. // 引入银行卡识别模型包
  7. implementation 'com.huawei.hms:ml-computer-card-bcr-model:1.0.3.300'
  8. }

1.3 在 AndroidManifest.xml 文件里面增量添加模型自动下载

要使应用程序能够在用户从华为应用市场安装您的应用程序后,自动将最新的机器学习模型更新到用户设备,请将以下语句添加到该应用程序的 AndroidManifest.xml 文件中:

  1. <manifest>
  2. ...
  3. <meta-data android:name="com.huawei.hms.ml.DEPENDENCY" android:value= "bcr"/>
  4. <!--If multiple models are required,set the parameter as follows:
  5. android:value="object,ocr,face,label,icr,bcr,imgseg"-->
  6. ...
  7. </manifest>

1.4 在 AndroidManifest.xml 文件里面申请相机和存储权限

  1. <!--相机权限-->
  2. <uses-permission android:name="android.permission.CAMERA" />
  3. <!--使用存储权限-->
  4. <uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" />

2 代码开发关键步骤

2.1 创建识别结果回调函数

重载 onSuccess, onCanceled, onFailure, onDenied 四个方法;onSuccess 表示识别成功,MLBcrCaptureResult 为识别返回结果,onCanceled 表示用户取消,onFailure 表示识别失败,onDenied 表示相机不可用等场景。

  1. private MLBcrCapture.Callback callback = new MLBcrCapture.Callback() {
  2. @Override
  3. public void onSuccess(MLBcrCaptureResult bankCardResult){
  4. // 识别成功处理。
  5. }
  6. @Override
  7. public void onCanceled(){
  8. // 用户取消处理。
  9. }
  10. // 识别不到任何文字信息或识别过程发生系统异常的回调方法。
  11. // retCode:错误码。
  12. // bitmap:检测失败的卡证图片。
  13. @Override
  14. public void onFailure(int retCode, Bitmap bitmap){
  15. // 识别异常处理。
  16. }
  17. @Override
  18. public void onDenied(){
  19. // 相机不支持等场景处理。
  20. }
  21. };

2.2 设置识别参数,调用识别器 captureFrame 接口进行识别,识别结果会通过步骤2.1的回调函数返回。

  1. private void startCaptureActivity(MLBcrCapture.Callback callback) {
  2. MLBcrCaptureConfig config = new MLBcrCaptureConfig.Factory()
  3. // 设置识别界面横竖屏,支持三种模式:
  4. // MLBcrCaptureConfig.ORIENTATION_AUTO: 自适应模式,由物理感应器决定显示方向。
  5. // MLBcrCaptureConfig.ORIENTATION_LANDSCAPE: 横屏模式。
  6. // MLBcrCaptureConfig.ORIENTATION_PORTRAIT: 竖屏模式。
  7. .setOrientation(MLBcrCaptureConfig.ORIENTATION_AUTO)
  8. .create();
  9. MLBcrCapture bankCapture = MLBcrCaptureFactory.getInstance().getBcrCapture(config);
  10. bankCapture.captureFrame(this, callback);
  11. }

2.3 在检测按钮的回调中,调用步骤2.2中定义的方法,实现银行卡识别。

  1. @Override
  2. public void onClick(View v) {
  3. switch (v.getId()) {
  4. // 检测按钮。
  5. case R.id.detect:
  6. startCaptureActivity(callback);
  7. break;
  8. default:
  9. break;
  10. }
  11. }

Demo效果

给大家看下 Demo 效果:

github源码

源码已经上传 github,大家也可以在 github 上一起完善该功能。

github 源码地址:https://github.com/HMS-MLKit/HUAWEI-HMS-MLKit-Sample

银行卡识别 demo 代码路径:MLKit-Sample\module-text\src\main\java\com\mlkit\sample\activity\BankCardRecognitionActivity.java

更详细的开发指南参考华为开发者联盟官网

华为开发者联盟机器学习服务开发指南

往期链接:

第一期:用华为 HMS MLKit SDK 三十分钟在安卓上开发一个微笑抓拍神器

https://developer.huawei.com/consumer/cn/forum/topicview?tid=0201198419687680377&fid=18

第二期:安卓开发实战,用华为 HMS MLKit 图像分割 SDK 开发一个证件照 DIY 小程序

https://developer.huawei.com/consumer/cn/forum/topicview?tid=0201203408959360433&fid=18

第三期:安卓开发实战,用 HMS MLKit 华为机器学习服务开发一个拍照翻译小程序

https://developer.huawei.com/consumer/cn/forum/topicview?tid=0201209905778120045&fid=18

下期预告

基于华为机器学习服务,后面还会有一系列的实战经验分享,大家可以持续关注~

超简单集成华为 HMS MLKit 机器学习服务:银行卡识别 SDK,一键实现银行卡绑定的更多相关文章

  1. 超简单集成华为HMS ML Kit文本识别SDK,一键实现账单号自动录入

    前言   在之前的文章<超简单集成华为HMS Core MLKit通用卡证识别SDK,一键实现各种卡绑定>中我们给大家介绍了华为HMS ML Kit通用卡证识别技术是如何通过拍照自动识别卡 ...

  2. 超简单集成 HMS ML Kit 实现最大脸微笑抓拍

    前言 如果大家对 HMS ML Kit 人脸检测功能有所了解,相信已经动手调用我们提供的接口编写自己的 APP 啦.目前就有小伙伴在调用接口的过程中反馈,不太清楚 HMS ML Kit 文档中的 ML ...

  3. HMS Core机器学习服务图像超分能力,基于深度学习提升新闻阅读体验

    在移动端阅读资讯时,人们对高分辨率.高质量的图像要求越来越高.但受限于网络流量.存储.图片源等诸多因素,用户无法便捷获得高质量图片.移动端显示设备的高分辨率图片获得问题亟待解决.不久前,HMS Cor ...

  4. Android | 教你如何用华为HMS MLKit SDK 三十分钟在安卓上开发一个微笑抓拍神器

    Android | 只要三十分钟就可以在手机上开发一个微笑抓拍神器!!! 前言 前段时间Richard Yu在发布会上给大家介绍了华为HMS Core4.0,回顾发布会信息请戳: 华为面向全球发布HM ...

  5. HMS Core机器学习服务助力Zaful用户便捷购物

    Zaful是近年来发展良好的出海电商平台,主打快时尚.在洞察其用户有购买街头海报.生活中同款衣物的需求后,Zaful联合HMS Core机器学习服务打造拍照购物服务.用户拍照后可在预设的商品图片库中搜 ...

  6. Android | 教你如何用华为HMS MLKit 图像分割 SDK开发一个证件照DIY小程序

    Android | 教你如何用华为HMS MLKit 图像分割 SDK开发一个证件照DIY小程序 引子   上期给大家介绍了如何使用如何用华为HMS MLKit SDK 三十分钟在安卓上开发一个微笑抓 ...

  7. HMS Core 机器学习服务6.4.0版本更新啦,文本翻译功能增加10种小语种语言类型!

    近日,HMS Core机器学习服务(ML Kit)文本翻译功能在6.4.0版本更新中增加了10种小语种语言类型,分别是马其他语.马其顿.冰岛.乌尔都语.波斯尼亚语.乌克兰语.加泰罗尼亚语.斯洛文尼亚语 ...

  8. 超简单集成ML kit 实现听写单词播报

    背景   相信我们大家在刚开始学习一门语言的时候都有过听写,现在的小学生学语文的时候一项重要的课后作业就是听写课文中的生词,很多家长们都有这方面的经历.不过一方面这种读单词的动作相对简单,另一方面家长 ...

  9. HMS Core 机器学习服务打造同传翻译新“声”态,AI让国际交流更顺畅

    2022年6月,HMS Core机器学习服务面向开发者提供一项全新的开放能力--同声传译,通过AI语音技术减少资源成本,加强沟通交流,旨在帮助开发者制作丰富多样的同声传译应用. HMS Core同声传 ...

随机推荐

  1. sqlmap之--os-shell命令执行原理

    最近也是在看sqlmap,感觉--os-shell这个命令确实很厉害,但我并不知道它的原理,所以来研究一下 环境 环境就是我本地搭的一个有sql注入漏洞的一个小demo 演示 这是我们的demo环境 ...

  2. Sentry 开发者贡献指南 - 配置 PyCharm

    概述 如果您使用 PyCharm 进行开发,则需要配置一些内容才能运行和调试. 本文档描述了一些对 sentry 开发有用的配置 配置 Python 解释器:(确保它是 venv 解释器)例如 ~/v ...

  3. 【解决了一个问题】腾讯云中使用ckafka生产消息时出现“kafka server: Message contents does not match its CRC.”错误

    初始化的主要代码如下: config := sarama.NewConfig() config.Producer.RequiredAcks = sarama.WaitForAll // Wait fo ...

  4. Tomcat-如何创建动态的web工程及目录介绍

    1,IDEA中如何创建动态web工程 (1)创建一个新模块 (2)选择你要创建什么类型的模块 (3)输入模块名,finish完成创建 创建成功如下图: 一般在WEB-INF下建一个lib目录 存放ja ...

  5. java内部类细节

    1 package face_09; 2 /* 3 * 为什么内部类能直接访问外部类中的成员呢? 4 * 那是因为内部类持有了外部类的引用. 外部类名.this 5 * 6 */ 7 class Ou ...

  6. thingsboard源码编译启动

    开发环境 不同的版本对应的开发环境不同(这里以3.3.3版本说明) jdk11+:参考jdk11+安装(win) Maven3.6+:Maven安装配置 Git:参考Git安装 IDEA: 参考IDE ...

  7. 如何在pyqt中实现亚克力磨砂效果的QLabel

    前言 Windows10 在 UWP 应用中支持亚克力画刷,可以在部件的底部绘制亚克力效果的背景图.下面我们使用 QLabel 来模拟这个磨砂过程. 实现方法 MSDN 文档中介绍了亚克力材料的配方, ...

  8. 如何使用自对弈强化学习训练一个五子棋机器人Alpha Gobang Zero

    前言 2016年3月,Alpha Go 与围棋世界冠军.职业九段棋手李世石进行围棋人机大战,以4比1的总比分获胜,在当时引起了轩然大波.2017年10月,谷歌公布了新版五子棋程序 AlphaGo Ze ...

  9. ABC231H(二分图最小权边覆盖)

    首先将行列分别抽象成 \(h, w\) 个点,每个格子视作连接两个点的一条边,那么问题就转化为了二分图最小权边覆盖问题. 考虑最后答案形如:若干组互不相交的匹配加上其他点连接到匹配内. 于此同时,不在 ...

  10. Shell中退出状态码exit

    shell中运行的每个命令都使用退出状态码(exit status)来告诉shell它完成了处理.退出状态码是一个0~255之间的整数值,在命令结束时由命令传回shell. 1 .查看退出状态码 Li ...