之前不是做了个开源项目嘛,在做完GitHub登录后,想着再显得有逼格一点,说要再加个人脸识别登录,就我这佛系的开发进度,过了一周总算是抽时间安排上了。源码在文末其实最近对写文章有点小抵触,写的东西没人看,总有点小失落,好在有同行大佬们的开导让我重拾了信心。调整了自己的心态,只要我分享的东西对大家有帮助就好,至于多少人看那就随缘吧!废话不多说先看人脸识别效果动态,马赛克有点重哈,没办法长相实在是拿不出手。


实现原理

我们看一下实现人脸识别登录的大致流程,三个主要步骤:


  1. 前端登录页打开摄像头,进行人脸识别,注意:只识别画面中是不是有人脸

  2. 识别到人脸后,拍照上传当前画面图片

  3. 后端接受图片并调用人脸库SDK,对人像进行比对,通过则登录成功,并将人像信息注册到人脸库和本地mysql

前端实现

上边说过要在前端识别到人脸,所以这里就不得不借助工具了,我使用的 tracking.js,一款轻量级的前端人脸识别框架。前端 Vue代码实现逻辑比较简单,tracking.js打开摄像头识别到人脸信息后,对视频图像拍照,将图片信息上传到后台,等待图片对比的结果就可以了。

data() {return {showContainer: true,   // 显示            tracker: null,tipFlag: false,         // 提示用户已经检测到            flag: false,            // 判断是否已经拍照            context: null,          // canvas上下文            removePhotoID: null,    // 停止转换图片            scanTip: '人脸识别中...',// 提示文字            imgUrl: '',              // base64格式图片            canvas: null        }    },    mounted() {this.playVideo()    },methods: {        playVideo() {var video = document.getElementById('video');this.canvas = document.getElementById('canvas');this.context = this.canvas.getContext('2d');this.tracker = new tracking.ObjectTracker('face');this.tracker.setInitialScale(4);this.tracker.setStepSize(2);this.tracker.setEdgesDensity(0.1);            tracking.track('#video', this.tracker, {camera: true});this.tracker.on('track', this.handleTracked);        },        handleTracked(event) {this.context.clearRect(0, 0, this.canvas.width, this.canvas.height);if (event.data.length === 0) {this.scanTip = '未识别到人脸'                } else {if (!this.tipFlag) {this.scanTip = '识别成功,正在拍照,请勿乱动~'                    }// 1秒后拍照,仅拍一次if (!this.flag) {this.scanTip = '拍照中...'this.flag = truethis.removePhotoID = setTimeout(() => {this.tackPhoto()this.tipFlag = true                            },2000                        )                    }                    event.data.forEach(this.plot);                }        },        plot(rect){this.context.strokeStyle = '#eb652e';this.context.strokeRect(rect.x, rect.y, rect.width, rect.height);this.context.font = '11px Helvetica';this.context.fillStyle = "#fff";this.context.fillText('x: ' + rect.x + 'px', rect.x + rect.width + 5, rect.y + 11);this.context.fillText('y: ' + rect.y + 'px', rect.x + rect.width + 5, rect.y + 22);        },// 拍照        tackPhoto() {this.context.drawImage(this.$refs.refVideo, 0, 0, 500, 500)// 保存为base64格式this.imgUrl = this.saveAsPNG(this.$refs.refCanvas)var formData = new FormData();            formData.append("file", this.imgUrl);this.scanTip = '登录中,请稍等~'            axios({method: 'post',url: '/faceDiscern',data: formData,            }).then(function (response) {                alert(response.data.data);window.location.href="http://127.0.0.1:8081/home";            }).catch(function (error) {console.log(error);            });this.close()        },// 保存为png,base64格式图片        saveAsPNG(c) {return c.toDataURL('image/png', 0.3)        },// 关闭并清理资源        close() {this.flag = falsethis.tipFlag = falsethis.showContainer = falsethis.tracker && this.tracker.removeListener('track', this.handleTracked) && tracking.track('#video', this.tracker, {camera: false});this.tracker = nullthis.context = nullthis.scanTip = ''            clearTimeout(this.removePhotoID)        }    }

人脸识别

之前也搞过一个人脸识别案例,不过调用SDK的方式太过繁琐,而且代码量巨大。所以这次为了简化实现,改用了百度的人脸识别API,没想到出乎意料的简单。别抬杠问我为啥不自己写人脸识别工具,别问,问就是不会在百度云注册一个应用 https://console.bce.baidu.com/ai/?_=1595996996657&fromai=1#/ai/face/app/list,得到 API KeySecret Key,为了后续获取 token用。


百度云人脸识别的API非常友好,各种操作的 demo都写好了,拿过来简单改改就可以。第一步先获取token,这是调用百度人脸识别API的基础。

https://aip.baidubce.com/oauth/2.0/token?grant_type=client_credentials&client_id=【百度云应用的AK】&client_secret=【百度云应用的SK】

接下来我们开始对图片进行比对,百度云提供了一个在线的人脸库,用户登录我们先在人脸库查询人像是否存在,存在则表示登录成功,如果不存在则注册到人脸库。每个图片有一个唯一标识face_token


百度人脸识别 API实现比较简单,需要特别注意参数image_type,它有三种类型

  • BASE64:图片的base64值,base64编码后的图片数据,编码后的图片大小不超过2M;
  • URL:图片的 URL地址( 可能由于网络等原因导致下载图片时间过长);
  • FACE_TOKEN:人脸图片的唯一标识,调用人脸检测接口时,会为每个人脸图片赋予一个唯一的FACE_TOKEN,同一张图片多次检测得到的FACE_TOKEN是同一个。

而我们这里使用的是图片BASE64文件,所以image_type要设置成BASE64

    @Override    public BaiDuFaceSearchResult faceSearch(String file) {try {            byte[] decode = Base64.decode(Base64Util.base64Process(file));String faceFile = Base64Util.encode(decode);Map<String, Object> map = new HashMap<>();            map.put("image", faceFile);            map.put("liveness_control", "NORMAL");            map.put("group_id_list", "user");            map.put("image_type", "BASE64");            map.put("quality_control", "LOW");String param = GsonUtils.toJson(map);String result = HttpUtil.post(faceSearchUrl, this.getAccessToken(), "application/json", param);            BaiDuFaceSearchResult searchResult = JSONObject.parseObject(result, BaiDuFaceSearchResult.class);            log.info(" faceSearch: {}", JSON.toJSONString(searchResult));return searchResult;        } catch (Exception e) {            log.error("get faceSearch error {}", e.getStackTrace());            e.getStackTrace();        }return null;    }    @Override    public BaiDuFaceDetectResult faceDetect(String file) {try {            byte[] decode = Base64.decode(Base64Util.base64Process(file));String faceFile = Base64Util.encode(decode);Map<String, Object> map = new HashMap<>();            map.put("image", faceFile);            map.put("face_field", "faceshape,facetype");            map.put("image_type", "BASE64");String param = GsonUtils.toJson(map);String result = HttpUtil.post(faceDetectUrl, this.getAccessToken(), "application/json", param);            BaiDuFaceDetectResult detectResult = JSONObject.parseObject(result, BaiDuFaceDetectResult.class);            log.info(" detectResult: {}", JSON.toJSONString(detectResult));return detectResult;        } catch (Exception e) {            log.error("get faceDetect error {}", e.getStackTrace());            e.getStackTrace();        }return null;    }    @Override    public BaiDuFaceAddResult addFace(String file, UserFaceInfo userFaceInfo) {try {            byte[] decode = Base64.decode(Base64Util.base64Process(file));String faceFile = Base64Util.encode(decode);Map<String, Object> map = new HashMap<>();            map.put("image", faceFile);            map.put("group_id", "user");            map.put("user_id", userFaceInfo.getUserId());            map.put("user_info", JSON.toJSONString(userFaceInfo));            map.put("liveness_control", "NORMAL");            map.put("image_type", "BASE64");            map.put("quality_control", "LOW");String param = GsonUtils.toJson(map);String result = HttpUtil.post(addfaceUrl, this.getAccessToken(), "application/json", param);            BaiDuFaceAddResult addResult = JSONObject.parseObject(result, BaiDuFaceAddResult.class);            log.info("addResult: {}", JSON.toJSONString(addResult));return addResult;        } catch (Exception e) {            log.error("get addFace error {}", e.getStackTrace());            e.getStackTrace();        }return null;    }

项目是前后端分离的,但为了大家学习方便,我把人脸识别页面整合到了后端项目。最后 run FireControllerApplication 访问地址:http://localhost:8082/face 即可。源码GitHub地址:https://github.com/chengxy-nds/fire.git

往期推荐

?

  • 真实用!推荐一款与Swagger媲美的数据库文档生成工具...
  • 怒爬某破Hub站资源,只为撸这个鉴黄平台!
  • 拼多多二面:Mybatis是如何执行一条SQL命令的?

 

点击

vb调用摄像头实现拍照源码_牛逼!终于搞了一个高大上的人脸识别登录玩玩(附源码),出乎意料的简单......相关推荐

  1. java人脸识别教程_用 Java 实现人脸识别功能(附源码)

    > 整理了一些Java方面的架构.面试资料(微服务.集群.分布式.中间件等),有需要的小伙伴可以关注公众号[程序员内点事],无套路自行领取 更多优选 引言 远程在家办公的第N天,快要闲出屁了,今 ...

  2. 用 Java 实现人脸识别功能(附源码)

    远程在家办公的第N天,快要闲出屁了,今天突然有个小学弟加我VX说要咨询我点技术问题(终于可以装X了). 看了他的需求描述,大概是要做一个Java web版本的人脸识别功能,然后存储人物的特征,再扫脸比 ...

  3. 人脸特性提取java_基于 Java 实现的人脸识别功能(附源码)

    引言 远程在家办公的第N天,快要闲出屁了,今天突然有个小学弟加我VX说要咨询我点技术问题(终于可以装X了).看了他的需求描述,大概是要做一个Java web版本的人脸识别功能,然后存储人物的特征,再扫 ...

  4. 牛逼的python代码_牛逼啊!一个随时随地写Python代码的神器

    现在学Python的人越来越多,很多小伙伴都非常有激情,利用碎片时间随时随地学习Python, 大家知道Python是一门编程语言,但是学语言光看不练是没有用的.最好能编程并运行,有没有什么好的神器可 ...

  5. python 深度学习源码_「深度学习」用TensorFlow实现人脸识别(附源码,快速get技能)...

    本文将会带你使用python码一个卷积神经网络模型,实现人脸识别,操作难度比较低,动手跟着做吧,让你的电脑认出你那帅气的脸. 由于代码篇幅较长,而且最重要的缩进都没了,建议直接打开源码或者点击分享-& ...

  6. python数据分析神器_牛逼啊!一个随时随地写Python代码的神器

    作者: Leoxin 公众号:菜鸟学Python 现在学Python的人越来越多,很多小伙伴都非常有激情.利用碎片时间随时随地学习Python, 大家知道Python是一门编程语言,但是学语言光看不练 ...

  7. java打字游戏代码_牛逼啊!一个随时随地写Python代码的神器

    现在学Python的人越来越多,很多小伙伴都非常有激情.利用碎片时间随时随地学习Python, 大家知道Python是一门编程语言,但是学语言光看不练是没有用的.最好能编程并运行,有没有什么好的神器可 ...

  8. 一个随时写python代码的神器_牛逼啊!一个随时随地写Python代码的神器

    现在学Python的人越来越多,很多小伙伴都非常有激情.利用碎片时间随时随地学习Python, 大家知道Python是一门编程语言,但是学语言光看不练是没有用的.最好能编程并运行,有没有什么好的神器可 ...

  9. c++ 二次开发 良田高拍仪_在网页中调用摄像头实现拍照上传 - 高拍仪二次开发...

    来源于  https://blog.csdn.net/weixin_40659738/article/details/78252562 在网页中调用摄像头实现拍照上传 高拍仪二次开发 在一些公共部门的 ...

  10. vue中如何调用ios摄像头_如何使用Vue2.0调用摄像头进行拍照

    这次给大家带来如何使用Vue2.0调用摄像头进行拍照,使用Vue2.0调用摄像头进行拍照的注意事项有哪些,下面就是实战案例,一起来看一下. import {Exif} from './exif.js' ...

最新文章

  1. V2V-PoseNet算法和应用详解(3D关节点估计领域)
  2. linux 内核钩子 khook 项目介绍
  3. 逻辑错误有哪些c语言,c语言程序,现在出现逻辑错误,哪位高手指点下啊。。。...
  4. 520这天,我突然意识到,她根本配不上我这么聪明的男人!
  5. Python列表的切片
  6. 第 7 章 异常处理结构、代码测试与调试
  7. 软件工程敏捷开发01
  8. 小程序【笔记001】框架和配置文件
  9. php 数组去impload,你真的了解 load 方法么?
  10. android 主题是什么,什么是Android中的AppCompat主题?
  11. ktv服务器管理系统,小型KTV综合解决方案
  12. Xshell 外观配置
  13. bou计算机术语,2012年计算机一级考试模拟试题及参考答案(27)
  14. unity之粒子特效制作图片拼合文字效果
  15. 追加安装sticky模块
  16. 最好的投资是投资自己:20本投资书单推荐
  17. 2023程序员找工作难?盘点目前IT各大热门行业,看看哪些更有前景
  18. astype函数的使用
  19. java 动态分区 链表_大二作业——操作系统实验——C语言用双向链表,模拟实现动态分区式存储管理...
  20. Spotfire经验总结—累积百分比(帕累托图)的绘制方法

热门文章

  1. 视频教程-SQL语句视频课程(进阶版)-Oracle
  2. C 语言是“最环保”的编程语言
  3. Ubuntu 14.04 设置静态IP地址全攻略
  4. java添加购物车代码_Java web实现购物车功能的示例代码
  5. vba把json转数组中_网抓处理Json数据 | VBA实例教程
  6. 触控屏c语言程序,触摸屏编程软件 C-more Micro Programming Software V3.0
  7. Java Web编程技术基础
  8. echarts-市地图
  9. Python核心编程第三版
  10. Java的测试方法有哪些?自动化测试让Java测试变得更简单!