通过调用API在JavaWeb项目中实现证件识别
本文详细介绍自己如何在JavaWeb项目中通过调用API实现证件识别。
一,Face++使用简介
二,两种方式(图片URL与本地上传)实现证件识别
一,Face++使用简介
Face++旷视人工智能开放平台,核心技术有人脸识别,人体识别,文字识别以及图像识别。具体详情可查看官方网站
首先需要在官方网站上注册,然后在API应用管理创建API Key,便可得到API Key和API Secret。两者是之后调用API的必要请求参数。
具体操作方式也可查看API文档

API调用原理:使用者向服务器发起HTTP请求,并加上合适的参数,服务器将会对请求进行处理,得到结果将会返回给使用者。
API调用鉴权:帐号下每创建一个应用程序会生成一组对应的API Key和API Secret,用于识别用户是否有权限调用API,所有的API调用必须提供对应的一组API Key和API Secret。
API调用参数:调用每个API需要根据需求传输不同的参数,身份证识别需要的必须参数有API的URL,API Key,API Secret,image_url或image_file或image_base64以及可选参数legality。
API调用提示:为了避免因网络问题而造成的阻塞,建议将API调用放进异步线程里执行。
二,两种方式(图片URL与本地上传)实现证件识别
不管是通过URL方式还是通过本地上传,调用API之前首先需要将图片转为字节型数组byte[]。官方给的案例只介绍了通过本地上传,我在其基础上添加了一个函数 'getBytesFromInputStream'实现将输入流转为字节型数组,代码如下。
①通过URL方式
当输入图片URL,点击检测按钮,触发js的click事件,首先根据URL完成修改img标签的背景图片,并将其传给 'readPhoto1' 函数。该函数将URL通过AJAX异步请求传至Controller层,Controller层通过URL首先建立网络连接得到输入流,输入流通过上述代码转为字节型数组,并put至HashMap中作为参数之一。另外两个参数已经是规定好的,这时再调用post函数,得到返回值转为JSON格式返回至 'readPhoto1' 函数,该函数再取值通过id赋值给相应的标签。参考代码如下。
$("#bg-model4_button2").click(function(){
var photoURL = document.getElementById("bg-model4_input").value;
document.getElementById('bg-model4_img').src = photoURL;
readPhoto1(photoURL);
});
/*通过URL读取图片*/
function readPhoto1(photoURL){
$.post("readPhotoInfo1.do",{photoURL},function(data){
document.getElementById("name").innerHTML = data.cards[0].name;
document.getElementById("sex").innerHTML = data.cards[0].gender;
document.getElementById("race").innerHTML = data.cards[0].race;
document.getElementById("birthday").innerHTML = data.cards[0].birthday;
document.getElementById("address").innerHTML = data.cards[0].address;
document.getElementById("idcard_num").innerHTML = data.cards[0].id_card_number;
if(data.cards[0].side == "front"){
document.getElementById("admin_side").innerHTML = "人像面";
}else{
document.getElementById("admin_side").innerHTML = "国徽面";
}
document.getElementById("admin_time_used").innerHTML = data.time_used + "ms";
},"json");
}
private String photoInfo; //身份证信息 //根据图片URL读取图片内容信息
@RequestMapping(value="/readPhotoInfo1.do",method=RequestMethod.POST)
public String readPhotoInfo1(HttpServletRequest request,HttpServletResponse response) throws IOException{
response.setContentType("text/html; charset=utf-8");
//js里通过ajax传递过来的图片URL
String photoURL = request.getParameter("photoURL");
URL photo_url = new URL(photoURL);
HttpURLConnection conn = (HttpURLConnection)photo_url.openConnection();
conn.setConnectTimeout(3*1000);
//防止屏蔽程序抓取而返回403错误
conn.setRequestProperty("User-Agent", "Mozilla/4.0 (compatible; MSIE 5.0; Windows NT; DigExt)");
//得到输入流
InputStream inputStream = conn.getInputStream();
byte[] buff = CertificateRecognition.getBytesFromInputStream(inputStream); //API的地址
String url = "https://api-cn.faceplusplus.com/cardpp/v1/ocridcard";
HashMap<String, String> map = new HashMap<>();
HashMap<String, byte[]> byteMap = new HashMap<>();
map.put("api_key", "你的api_key");
map.put("api_secret", "你的api_secret");
map.put("return_landmark", "1");
map.put("return_attributes", "gender,age,smiling,headpose,facequality,blur,eyestatus,emotion,ethnicity,beauty,mouthstatus,eyegaze,skinstatus");
byteMap.put("image_file", buff);
PrintWriter out = response.getWriter(); callPost(url, map, byteMap, out);
out.close();
return null;
}
//调用CertificateRecognition中的post方法
private void callPost(String url, HashMap<String, String> map, HashMap<String, byte[]> byteMap, PrintWriter pw) {
try{
byte[] bacd = CertificateRecognition.post(url, map, byteMap);
this.photoInfo = new String(bacd);
pw.println(photoInfo);
System.out.println(photoInfo);
}catch (Exception e) {
e.printStackTrace();
}
}
②通过本地上传方式
当选择本地图片,由于绑定js的change事件,首先完成修改img标签的背景图片,这里的js得到的是本地图片的base64编码,并将其传给'readPhoto2'函数。该函数将的base64编码通过AJAX异步请求传至Controller层,Controller层首先需要对图片的base64编码进行截取(前缀data:image/ jpeg; base64,为无效字符串),并调整异常数据,再将其写入本地一个规定的绝对路径。然后同理通过上述代码转为字节型数组,并将其put至HashMap中作为参数之一。这时再调用post函数,得到返回值并转为JSON格式返回至' readPhoto2'函数,该函数再取值通过id赋值给相应的标签。参考代码如下。
$("#admin_upload_photo").change(function(){
if(window.FileReader){ //chrome,firefox7+,opera,IE10,IE9,IE9也可以用滤镜来实现
oFReader = new FileReader();
oFReader.readAsDataURL(this.files[0]);
oFReader.onload = function (oFREvent) {
document.getElementById('bg-model4_img').src = oFREvent.target.result;
var base64 = oFREvent.target.result;
alert(base64);
readPhoto2(base64);
};
}
});
/*通过绝对路径读取图片*/
function readPhoto2(base64){
$.post("readPhotoInfo2.do",{base64},function(data){
document.getElementById("name").innerHTML = data.cards[0].name;
document.getElementById("sex").innerHTML = data.cards[0].gender;
document.getElementById("race").innerHTML = data.cards[0].race;
document.getElementById("birthday").innerHTML = data.cards[0].birthday;
document.getElementById("address").innerHTML = data.cards[0].address;
document.getElementById("idcard_num").innerHTML = data.cards[0].id_card_number;
if(data.cards[0].side == "front"){
document.getElementById("admin_side").innerHTML = "人像面";
}else{
document.getElementById("admin_side").innerHTML = "国徽面";
}
document.getElementById("admin_time_used").innerHTML = data.time_used + "ms";
},"json");
}
//根据图片绝对路径读取图片内容信息
@RequestMapping(value="/readPhotoInfo2.do",method=RequestMethod.POST)
public String readPhotoInfo2(HttpServletRequest request,HttpServletResponse response) throws IOException{
response.setContentType("text/html; charset=utf-8");
//js里通过ajax传递过来的图片base64编码
String base64 = request.getParameter("base64");
int size = base64.indexOf(","); //截取第一个,号后面的字符串
System.out.println(size); // String substr = base64.substring(22); BASE64Decoder decoder = new BASE64Decoder();
try
{
byte[] b = decoder.decodeBuffer(substr);
for(int i=0;i<b.length;++i) //调整异常数据
{
if(b[i]<0){
b[i] += 256;
}
}
String imgFilePath = "e:/base.png"; //新生成的图片存放路径
OutputStream out = new FileOutputStream(imgFilePath);
out.write(b);
out.flush();
out.close(); File file = new File(imgFilePath);
byte[] buff = CertificateRecognition.getBytesFromFile(file); //API的地址
String url = "https://api-cn.faceplusplus.com/cardpp/v1/ocridcard";
HashMap<String, String> map = new HashMap<>();
HashMap<String, byte[]> byteMap = new HashMap<>();
map.put("api_key", "你的api_key");
map.put("api_secret", "你的api_secret");
map.put("return_landmark", "1");
map.put("return_attributes", "gender,age,smiling,headpose,facequality,blur,eyestatus,emotion,ethnicity,beauty,mouthstatus,eyegaze,skinstatus");
byteMap.put("image_file", buff);
PrintWriter pw = response.getWriter(); callPost(url, map, byteMap, pw);
pw.close(); }
catch (Exception e){
e.printStackTrace();
}
return null;
}
项目效果图如下(证件图片是在网上任意找的一张图片,不针对于任何人)。

如有疏漏错误之处,还请不吝赐教!
通过调用API在JavaWeb项目中实现证件识别的更多相关文章
- log4j在javaWeb项目中的使用
在前边的文章中对log4j的配置文件进行了说明,今天介绍如何在普通的javaWeb项目中使用log4j. 在日常的开发过程中,日志使用的很频繁,我们可以利用日志来跟踪程序的错误,程序运行时的输出参数等 ...
- JavaWeb 项目中的绝对路径和相对路径以及问题的解决方式
近期在做JavaWeb项目,总是出现各种的路径错误,并且发现不同情况下 / 所代表的含义不同,导致在调试路径上浪费了大量时间. 在JavaWeb项目中尽量使用绝对路径 由于使用绝对路径是绝对不会出 ...
- 关联分析FPGrowth算法在JavaWeb项目中的应用
关联分析(关联挖掘)是指在交易数据.关系数据或其他信息载体中,查找存在于项目集合或对象集合之间的频繁模式.关联.相关性或因果结构.关联分析的一个典型例子是购物篮分析.通过发现顾客放入购物篮中不同商品之 ...
- Druid使用起步—在javaWeb项目中配置监控 连接池
当我们在javaWEB项目中使用到druid来作为我们的连接池的时候,一定不会忘了添加监控功能.下面我们就来看一下,在一个简单的web项目中(尚未使用任何框架)我们是如果来配置我们的web.xml来完 ...
- JavaWeb项目中web.xml有关servlet的基本配置
JavaWeb项目中web.xml有关servlet的基本配置: 我们注意到,tomcat下的conf中也有一个web.xml文件,没错的,所有的JavaWeb项目中web.xml都继承自服务器下的w ...
- ElasticSearch搜索引擎在JavaWeb项目中的应用
近几篇ElasticSearch系列: 1.阿里云服务器Linux系统安装配置ElasticSearch搜索引擎 2.Linux系统中ElasticSearch搜索引擎安装配置Head插件 3.Ela ...
- Javaweb项目中出现java.sql.SQLException: The server time zone value '�й���ʱ��' is unrecognized or represents more than one time zone.异常
javaweb项目中java.sql.SQLException: The server time zone value '�й���ʱ��' is unrecognized or represent ...
- javaweb项目中遇到的一些乱码问题
在做javaweb项目时,我们经常会遇到一些乱码问题: 首先,确定一点思想:要想不乱码,你要保证编码一致就行了,即统一编码~ 其一,jsp等页面中的中文显示乱码(这里不只是说jsp文件,其它文件也有这 ...
- javaweb项目中嵌入webservice--axis2
由于最近项目中需要搭建webservice服务端,由于原项目是javaweb项目,所以需要整合.之前用cxf试了,启动老是报错,maven依赖冲突.后来索性换成axis2 百度了一圈,下面这个博客 h ...
随机推荐
- [18/11/7] Java的基础概念
java语言的优势是跨平台 ,计算机界的英语,是IT行业的第一大语言 特点是多线程 分布式 健壮性 面向对象 java和JavaScript的关系 雷锋和雷峰塔的关系 或卡巴斯基和巴基斯坦的关系有个基 ...
- 对接融云即时通讯组件SDK,轻松实现App聊天室
我好像特别喜欢做聊天室类的东东,刚折腾完微软的SignalR又折腾App.本来想研究研究XMPP的,由于服务器的搭建问题,先采用一个第三方的吧,看看效果如何.听到弟弟说他们公司用到了融云,我也下载个S ...
- Joker
人生的第一位老师当然是我的爸妈,他们生我下来,教我学会走路讲话,教会我做人的道理,当然,他们还给我名字.人生的第二位老师就是我的初中老师,初中班主任对我非常好,在之后的考上市一中也是其中的缘由,初中班 ...
- Android学习笔记_39_tween动画的实现(Animation和Frame)
一.Animation动画的实现及特点: 1.Tween动画,通过对 View 的内容进行一系列的图形变换 (包括平移.缩放.旋转.改变透明度)来实现动画效果. 动画效果的定义可以采用XML来做也 ...
- 课时90.div和span(掌握)
为什么在这里讲解div和span呢,而不在html中讲解呢? 因为在我们的开发中div和span一般是配合css来使用的,来完成一定的效果,来设置一些属性,在前面我们没有学习css,所以体会不到它的效 ...
- DHTML---HTML5
1. HTML概述 网页是网站的表现层,各种编程语言(如Java)构成后台的逻辑,我们将后台逻辑做好然后通过页面表达.同时通过网页来与后台进行交互.而Html是我们做网页的基础,由浏览器来解析. 1. ...
- MySQL的数据类型(一)
每一个常量.变量和参数都有数据类型.它用来指定一定的存储格式.约束和有效范围.MySQL提供了多种数据类型.主要有数值型.字符串类型.日期和时间类型.不同的MySQL版本支持的数据类型可能会稍有不同. ...
- ssm整合实现注册与登录功能
最简洁易懂的SSM整合源码都在这里了 激情提示: 1.本项目是用IDEA编写的,不管你是习惯何种ide工具,那也只是工具而已,源代码才是本质 2.本项目只拥有注册和登录功能,简易的功能和详细的注释,是 ...
- js前台加密,java后端解密
1.前台JS <script type="text/javascript"> $(function() { $(" ...
- 2018/7/19 考试(tower,work,holes)
noip模拟赛,挺良心的题,考的贼烂(膜一下@来日方长大佬(sdfz rank1)) 不多说了,看题吧 1.tower 题面: 铁塔(tower.pas/c/cpp) 题目描述 Rainbow和Fre ...