Java教程:PC人脸识别登录,竟然出乎意料的简单

        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 = true
                    this.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 = false
        this.tipFlag = false
        this.showContainer = false
        this.tracker && this.tracker.removeListener('track', this.handleTracked) && tracking.track('#video', this.tracker, {camera: false});
        this.tracker = null
        this.context = null
        this.scanTip = ''
        clearTimeout(this.removePhotoID)
    }
}

**人脸识别**


之前也搞过一个人脸识别案例,不过调用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);
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值