提起AI,想必大家感觉就是神秘莫测,结合现实。今天看了一下BaiduOCR的技术支持,大概实现了身份证,银行卡,机动车牌,图片审核,这几个案例的识别。不得不说百度对图像的处理还是很强大的。根据开源出来的接口实现对以上功能的开发还是不错的。

废话不多说,既然那么神秘,我们也可以试着自己做一个识别Demo,案例会在最下方提供
1.点击链接BaiduAI

进入控制台登陆自己的百度云账号

2.登陆成功会进入自己的控制台,默认开通的服务如下

我们以文字识别为例,点击文字识别,

可以看到可用服务列表,并不是绝对免费的。但是程序员拿来装X应该没问题

3.创建应用

图中信息很明确,根据自己需要勾选相应的功能,当然部分功能是收费的,具体收费标准点这里

因为程序语言为Object-C 运用于ios上,所以这里我直接勾选如上图,(这里需要注意一点,包名绑定这里,必须要绑定自己创建的工程Bundle Identifier。要不等你一切做好之后发现会提示不匹配工程)确认无误后点击立即创建

创建成功,点击应用详情,进入自己创建的应用查看详情

拿到了自己的APPID,APIKey,SecretKey,记得保存一份,等下项目中要想实现以上功能必须通过这几个东西生成BaiduOCR的Token用,才可以。下边的API列表很详细的告诉我们当前这个项目接入的Api同时收费情况一目了然。很清晰。

4.接入服务

到了这一步,相信你已经成为一名合格的百度OCR的开发者了。下边开始把OCR服务接入我们工程
1.获取百度OCR Access Token
根据官方文档获取Access Token并保存到本地(注意token有效期为30天,过期需要重新获取接口保存token)

static NSString * const BaiduAppID           = @"9991413";
static NSString * const BaiduApiKey          = @"E2jIt1TZqt1EVYGVdH3L1Tb3";
static NSString * const BaiduSecretKey       = @"kIf9V9BktenQCFG8EpmlWChvlTz6GKbl";
static NSString * const BaiduAccess_tokenUrl = @"https://aip.baidubce.com/oauth/2.0/token";
#pragma mark - 获取百度AIAccess Token。有效期为30天
- (void)getBaiduAIAccessToken{/*请求URL数据格式向授权服务地址https://aip.baidubce.com/oauth/2.0/token发送请求(推荐使用POST),并在URL中带上以下参数:grant_type: 必须参数,固定为client_credentials;client_id: 必须参数,应用的API Key;client_secret: 必须参数,应用的Secret Key;https://aip.baidubce.com/oauth/2.0/token?grant_type=client_credentials&client_id=Va5yQRHlA4Fq4eR3LT0vuXV4&client_secret= 0rDSjzQ20XUj5itV7WRtznPQSzr5pVw2&*///    [[AipOcrService shardService] authWithAK:@"sLdWP9rGQ7iu63Pi4hvUP3qw" andSK:@"WF2fWKb8lQ2bfGB5MAAsixIGXCUzWipX"];NSMutableDictionary * dictionary = [[NSMutableDictionary alloc]init];[dictionary setObject:@"client_credentials" forKey:@"grant_type"];[dictionary setObject:BaiduApiKey forKey:@"client_id"];[dictionary setObject:BaiduSecretKey forKey:@"client_secret"];[NetWorkTool postNetWorkWithURL:BaiduAccess_tokenUrl paramaters:dictionary success:^(id object) {NSLog(@"%@",object);NSString * access_token = [object objectForKey:@"access_token"];NSString * expiresHaveTime = [NSString stringWithFormat:@"%@",[object objectForKey:@"expires_in"]];[[NSUserDefaults standardUserDefaults] setObject:access_token forKey:AccessTokenKey];[[NSUserDefaults standardUserDefaults] setObject:expiresHaveTime forKey:TokenValidity];[[NSUserDefaults standardUserDefaults] synchronize];NSInteger validityTime = [expiresHaveTime integerValue];if (validityTime <=0 || !validityTime) {UIAlertController * alertC = [UIAlertController alertControllerWithTitle:@"Warring" message:@"您使用的百度AI识别功能Access_Token已失效,请重新获取" preferredStyle:UIAlertControllerStyleActionSheet];UIAlertAction * confirmAction = [UIAlertAction actionWithTitle:@"确定" style:UIAlertActionStyleDefault handler:^(UIAlertAction * _Nonnull action) {[self.window.rootViewController dismissViewControllerAnimated:YES completion:^{}];}];[alertC addAction:confirmAction];[self.window.rootViewController presentViewController:alertC animated:YES completion:nil];}} failure:^(id failure) {NSLog(@"%@",failure);}];
}
这里请求数据用到了自己对AFNetworking的简单封装,有兴趣可以到文章最后Demo地址进行查看

获取Access Token 成功的话,我们可以根据AI开放平台中的文字识别API技术文档来搞事情了。

以身份证识别为例

从官方给出的API文档可以看出,通过POST方法向BaiduAI服务器发起请求,重点是链接中必须携带刚才获取的Access Token,由此可以看出我们在百度AI平台创建应用的重要性了。。。

头部需携带一下参数
Content-Type    application/x-www-form-urlencoded
重要的是Body中带的参数,

可以看出 image是必须携带的,并且要求还很多

图像数据,base64编码,要求base64编码后大小不超过4M,最短边至少15px,最长边最大4096px,支持jpg/png/bmp格式

要求一大串,不过没办法。想要获取到数据,还是要老老实实跟着文档走。这个提出一个坑。卡了三天没找到原因(其实我也没那么笨啊)

base64编码,对于这个东西,真没细心理解过。百度给出以下定义/*NSDataBase64Encoding64CharacterLineLength其作用是将生成的Base64字符串按照64个字符长度进行等分换行NSDataBase64Encoding76CharacterLineLength其作用是将生成的Base64字符串按照76个字符长度进行等分换行NSDataBase64EncodingEndLineWithCarriageReturn其作用是将生成的Base64字符串以回车结束NSDataBase64EncodingEndLineWithLineFeed其作用是将生成的Base64字符串以换行结束。*/
亲测只有使用了NSDataBase64EncodingEndLineWithCarriageReturn这个枚举的时候,图片识别才不会报图片格式错误。具体原因不详。有知道的麻烦不辞辛苦告知下
请求代码示例
身份证识别
curl -i -k 'https://aip.baidubce.com/rest/2.0/ocr/v1/idcard?access_token=24.f2c915b857ee62189abb7f92df0e8453.2592000.1499493935.282335-9395294' --data 'id_card_side=front&image=【图片Base64编码,需UrlEncode】' -H 'Content-Type:application/x-www-form-urlencoded'

到这里,其实基本功能已经实现。我们正常的通过拍照,或者相册中获取过来的图片,就可以识别出来了。

如果还想看更多的比如银行卡,车牌号,图文识别等的实现,请移步到我的GitHub地址
本文为个人原创,未经本人允许,禁止转载。

BaiduOCR实现身份证,银行卡,机动车牌,图像审核等识别相关推荐

  1. 身份证、银行卡、车牌、图片文字识别、黄图识别、驾驶证识别库实现功能

    预览图效果: 原文来自:http://code.662p.com/view/19388.html  ,需要自己去下载就可以了. 使用 依赖 implementation 'com.shouzhong: ...

  2. 通用卡证信息高精度识别流程 OCR 文本检测 文本识别 身份证 银行卡

    目录 如何将一张身份证图像的信息识别出来? 身份证识别点我 银行卡识别点我 第一步 目标检测 第二步 图像校正 如何获取匹配点对坐标 求解透视变换矩阵 第三步 文本检测 CTPN 第四步 文本识别 C ...

  3. 机动车号牌图像自动识别技术规范

    前 言. III 1 范围. 1 2 规范性引用文件. 1 3术语和定义. 1 4 技术要求. 1 5 接口函数. 2 6 信息交换格式. 3 前 言 本标准的全部技术内容为强制性. 本标准由公安部交 ...

  4. 图像审核产品“侦图” —— Milvus 在翼支付风控场景中的应用

    本文从翼支付风控的实际应用场景出发,介绍了图像审核产品"侦图"如何检测虚假营业执照,店内门头照.相似模板照的识别问题,"侦图"产品通过引入 Milvus 来进行 ...

  5. Amazon Rekognition - 图像审核

    Amazon Rekognition - 图像审核 https://amazonaws-china.com/cn/rekognition/faqs/ 问:什么是图像审核? Amazon Rekogni ...

  6. Regex:身份证号码和车牌号码正则表达式

    实名认证时,常会用到身份证号码和车牌号码的正则表达式匹配验证.简单高效. 经过一次一次的测试,去除多种匹配的表达式,得出相对正确的正则表达式. 1.车牌号正则匹配 车牌号组成规则 1.民用常规车牌号 ...

  7. Java调用百度API实现文本与图像审核功能

    文档: API文档:https://ai.baidu.com/ai-doc/ANTIPORN/ek3h6x90n SDK下载:https://ai.baidu.com/sdk#anti github链 ...

  8. php 调用百度AI实现图像审核功能

    今天主要记录下我完成百度AI实现图像审核功能做出可笑的行为,哈哈哈!! 废话不多说,开始了············ 各位准备好了没有.. 1.首先肯定是登录 百度AI开放平台了,没有账号的同志自行注册 ...

  9. SpringBoot项目调用百度API 实现文本与图像审核功能

    SpringBoot项目调用百度API 实现文本与图像审核功能 最近在开发一款微信小程序,其中具有发布帖子的功能,因此需要审核发布的文本与图像(不然开发的微信小程序过不了审).本来是调用微信小程序的A ...

最新文章

  1. ie浏览器修复工具_电脑故障修复不求人!50个小工具可帮你一键修复
  2. 基于系统级触发器的审计功能
  3. 你刚才淘宝上买衣服---具体分析技术工艺(淘宝页面显示处理的页面)
  4. 计算机网络的含义是什么意思,互联网的基本含义是什么
  5. python将excel表按地方拆分_Python将一个Excel拆分为多个Excel
  6. Deploy过程出错解决
  7. Android播放外部音乐文件
  8. mysql join联接_MySQL_join连接
  9. 自建服务器解网络锁,跟断刀学越狱】10分钟掌握iPhone1-4代刷机技巧
  10. LSTM模型结合动态SIR模型
  11. 千锋2015.04月最新C语言基础视频教程
  12. error: Microsoft Visual C++ 14.0 is required. Get it with “Build Tools for Visual Studio“: https://
  13. 2019年年终总结及明年的期望
  14. 【基于微信的物品回收小程序的设计与实现】
  15. 洛谷P1359 租用游艇
  16. elasticsearch的.security-7索引崩溃恢复笔记
  17. office2007 向程序发送命令时出现问题 的解决办法
  18. HZNUOJ 1019 取火柴
  19. Prometheus 邮件告警自定义模板的触发时间为utc的解决方法
  20. 设备漏电对计算机影响,机箱漏电会不会影响电脑 机箱漏电会不会烧电脑主机内部硬件吗...

热门文章

  1. 初识ollvm控制流平坦化
  2. 开源!用于3D激光雷达SLAM回环检测的实时词袋模型BoW3D
  3. CK默认存储目录迁移
  4. 手机斗鱼tv显示与服务器通讯失败,热门手机知识:斗鱼直播加载失败如何解决?解决斗鱼直播加载失败操作步骤...
  5. 2015年二本投档线
  6. 上传并在地图中显示Shp文件
  7. proguard配置选项
  8. Bk3435 蓝牙门锁,配件 开关锁代码
  9. iMazing如何恢复苹果手机被下架App软件应用
  10. QGC增加 google中国地图