“
本文收录在个人博客:www.chengxy-nds.top,技术资源共享。
之前不是做了个开源项目嘛,在做完GitHub
登录后,想着再显得有逼格一点,说要再加个人脸识别登录,就我这佛系的开发进度,过了一周总算是抽时间安排上了。
源码在文末
其实最近对写文章有点小抵触,写的东西没人看,总有点小失落,好在有同行大佬们的开导让我重拾了信心。调整了自己的心态,只要我分享的东西对大家有帮助就好,至于多少人看那就随缘吧!
废话不多说先看人脸识别效果动态,马赛克有点重哈,没办法长相实在是拿不出手。
实现原理
我们看一下实现人脸识别登录的大致流程,三个主要步骤:
- 前端登录页打开摄像头,进行人脸识别,注意:只识别画面中是不是有人脸
- 识别到人脸后,拍照上传当前画面图片
- 后端接受图片并调用人脸库SDK,对人像进行比对,通过则登录成功,并将人像信息注册到人脸库和本地
mysql
。
前端实现
上边说过要在前端识别到人脸,所以这里就不得不借助工具了,我使用的 tracking.js,一款轻量级的前端人脸识别框架。
前端 Vue
代码实现逻辑比较简单,tracking.js
打开摄像头识别到人脸信息后,对视频图像拍照,将图片信息上传到后台,等待图片对比的结果就可以了。
1 | 复制代码data() { |
人脸识别
之前也搞过一个人脸识别案例 《基于 Java 实现的人脸识别功能(附源码)》 ,不过调用SDK的方式太过繁琐,而且代码量巨大。所以这次为了简化实现,改用了百度的人脸识别API,没想到出乎意料的简单。
“
别抬杠问我为啥不自己写人脸识别工具,别问,问就是不会
在百度云注册一个应用 https://console.bce.baidu.com/ai/?_=1595996996657&fromai=1#/ai/face/app/list
,得到 API Key
和 Secret Key
,为了后续获取 token
用。
在这里插入图片描述
百度云人脸识别的API非常友好,各种操作的 demo都写好了,拿过来简单改改就可以。
第一步先获取token
,这是调用百度人脸识别API
的基础。
1 | 复制代码https://aip.baidubce.com/oauth/2.0/token? |
接下来我们开始对图片进行比对,百度云提供了一个在线的人脸库,用户登录我们先在人脸库查询人像是否存在,存在则表示登录成功,如果不存在则注册到人脸库。每个图片有一个唯一标识face_token
。
百度人脸识别 API
实现比较简单,需要特别注意参数image_type
,它有三种类型
BASE64
:图片的base64值,base64编码后的图片数据,编码后的图片大小不超过2M;URL
:图片的URL
地址( 可能由于网络等原因导致下载图片时间过长);FACE_TOKEN
:人脸图片的唯一标识,调用人脸检测接口时,会为每个人脸图片赋予一个唯一的FACE_TOKEN
,同一张图片多次检测得到的FACE_TOKEN
是同一个。
而我们这里使用的是图片BASE64
文件,所以image_type
要设置成BASE64
。
1 | 复制代码 @Override |
项目是前后端分离的,但为了大家学习方便,我把人脸识别页面整合到了后端项目。
最后 run FireControllerApplication 访问地址:http://localhost:8082/face 即可。
源码GitHub
地址:https://github.com/chengxy-nds/fire.git
,欢迎大家来耍~
原创不易,燃烧秀发输出内容,如果有一丢丢收获,点个赞鼓励一下吧!
整理了几百本各类技术电子书,送给小伙伴们。关注公号回复【666】自行领取。和一些小伙伴们建了一个技术交流群,一起探讨技术、分享技术资料,旨在共同学习进步,如果感兴趣就加入我们吧!
本文转载自: 掘金