2024年网络安全最全Java教程:PC人脸识别登录,竟然出乎意料的简单(1)


**人脸识别**


之前也搞过一个人脸识别案例,不过调用SDK的方式太过繁琐,而且代码量巨大。所以这次为了简化实现,改用了百度的人脸识别API,没想到出乎意料的简单。



> 
> 别抬杠问我为啥不自己写人脸识别工具,别问,问就是不会
> 
> 
> 


![Java教程:PC人脸识别登录,竟然出乎意料的简单](https://imgconvert.csdnimg.cn/aHR0cDovL3A2LXR0LmJ5dGVpbWcuY29tL2xhcmdlL3BnYy1pbWFnZS9hNmQ4MmMyZjk2MDc0ZTBmYmVmMzRlMjczOTRhMjVmYQ?x-oss-process=image/format,png)


百度云人脸识别的API非常友好,各种操作的 demo都写好了,拿过来简单改改就可以。


第一步先获取token,这是调用百度人脸识别API的基础。




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


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


![Java教程:PC人脸识别登录,竟然出乎意料的简单](https://imgconvert.csdnimg.cn/aHR0cDovL3AxLXR0LmJ5dGVpbWcuY29tL2xhcmdlL3BnYy1pbWFnZS8yMTgzNzNmMzVjYTM0Njk0OTc5NjkyNGQwMmQwOWVmOA?x-oss-process=image/format,png)


百度人脸识别 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;
}


项目是前后端分离的,但为了大家学习方便,我把人脸识别页面整合到了后端项目。




## 最后

**自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。**

**深知大多数网络安全工程师,想要提升技能,往往是自己摸索成长,但自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!**

**因此收集整理了一份《2024年网络安全全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友。**

![img](https://img-blog.csdnimg.cn/img_convert/0ea01e6cc8952d24ed4cfa14a8189f92.png)

![img](https://img-blog.csdnimg.cn/img_convert/6965270b90cb3a1c2c3e531870edb1f3.png)

![img](https://img-blog.csdnimg.cn/img_convert/de54aa935d1c23423b6a497a64330fe5.png)

![img](https://img-blog.csdnimg.cn/img_convert/b0ceb1fd2102c16cb368f538f14fe446.png)

![img](https://img-blog.csdnimg.cn/img_convert/bed9887c5a8e6f7ee5579b81bddf1111.png)

 

**既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上网络安全知识点!真正的体系化!**

[**如果你觉得这些内容对你有帮助,需要这份全套学习资料的朋友可以戳我获取!!**](https://bbs.csdn.net/topics/618653875)

**由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!**

网络安全知识点!真正的体系化!**

[**如果你觉得这些内容对你有帮助,需要这份全套学习资料的朋友可以戳我获取!!**](https://bbs.csdn.net/topics/618653875)

**由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!**

  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值