自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

PC人臉識別登錄,出乎意料的簡單

開發(fā) 后端 人臉識別
之前不是做了個開源項目嘛,在做完GitHub登錄后,想著再顯得有逼格一點,說要再加個人臉識別登錄,就我這佛系的開發(fā)進(jìn)度,過了一周總算是抽時間安排上了。

之前不是做了個開源項目嘛,在做完GitHub登錄后,想著再顯得有逼格一點,說要再加個人臉識別登錄,就我這佛系的開發(fā)進(jìn)度,過了一周總算是抽時間安排上了。

源碼在文末

其實最近對寫文章有點小抵觸,寫的東西沒人看,總有點小失落,好在有同行大佬們的開導(dǎo)讓我重拾了信心。調(diào)整了自己的心態(tài),只要我分享的東西對大家有幫助就好,至于多少人看那就隨緣吧!

廢話不多說先看人臉識別效果動態(tài),馬賽克有點重哈,沒辦法長相實在是拿不出手。

[[335574]]

實現(xiàn)原理

我們看一下實現(xiàn)人臉識別登錄的大致流程,三個主要步驟:

前端登錄頁打開攝像頭,進(jìn)行人臉識別,注意:只識別畫面中是不是有人臉

識別到人臉后,拍照上傳當(dāng)前畫面圖片

后端接受圖片并調(diào)用人臉庫SDK,對人像進(jìn)行比對,通過則登錄成功,并將人像信息注冊到人臉庫和本地mysql。

前端實現(xiàn)

上邊說過要在前端識別到人臉,所以這里就不得不借助工具了,我使用的 tracking.js,一款輕量級的前端人臉識別框架。

前端 Vue 代碼實現(xiàn)邏輯比較簡單,tracking.js 打開攝像頭識別到人臉信息后,對視頻圖像拍照,將圖片信息上傳到后臺,等待圖片對比的結(jié)果就可以了。

 

  1. data() {  
  2.         return {  
  3.             showContainer: true,   // 顯示  
  4.             tracker: null,  
  5.             tipFlag: false,         // 提示用戶已經(jīng)檢測到  
  6.             flag: false,            // 判斷是否已經(jīng)拍照  
  7.             context: null,          // canvas上下文  
  8.             removePhotoID: null,    // 停止轉(zhuǎn)換圖片  
  9.             scanTip: '人臉識別中...',// 提示文字  
  10.             imgUrl: '',              // base64格式圖片  
  11.             canvas: null  
  12.         }  
  13.     },  
  14.     mounted() {  
  15.         this.playVideo()  
  16.     },  
  17.     methods: {  
  18.         playVideo() {  
  19.             var video = document.getElementById('video');  
  20.             this.canvas = document.getElementById('canvas');  
  21.             thisthis.context = this.canvas.getContext('2d');  
  22.             this.tracker = new tracking.ObjectTracker('face');  
  23.             this.tracker.setInitialScale(4);  
  24.             this.tracker.setStepSize(2);  
  25.             this.tracker.setEdgesDensity(0.1);  
  26.             tracking.track('#video', this.tracker, {camera: true});  
  27.             this.tracker.on('track', this.handleTracked);  
  28.         },  
  29.         handleTracked(event) { 
  30.                  this.context.clearRect(0, 0, this.canvas.width, this.canvas.height);  
  31.                 if (event.data.length === 0) {  
  32.                     this.scanTip = '未識別到人臉'  
  33.                 } else {  
  34.                     if (!this.tipFlag) {  
  35.                         this.scanTip = '識別成功,正在拍照,請勿亂動~'  
  36.                     }  
  37.                     // 1秒后拍照,僅拍一次  
  38.                     if (!this.flag) {  
  39.                         this.scanTip = '拍照中...'  
  40.                         this.flag = true  
  41.                         this.removePhotoID = setTimeout(() => {  
  42.                                 this.tackPhoto()  
  43.                                 this.tipFlag = true  
  44.                             },  
  45.                             2000  
  46.                         )  
  47.                     }  
  48.                     event.data.forEach(this.plot);  
  49.                 } 
  50.         },  
  51.         plot(rect){  
  52.             this.context.strokeStyle = '#eb652e' 
  53.             this.context.strokeRect(rect.x, rect.y, rect.width, rect.height);  
  54.             this.context.font = '11px Helvetica' 
  55.             this.context.fillStyle = "#fff" 
  56.             this.context.fillText('x: ' + rect.x + 'px', rect.x + rect.width + 5, rect.y + 11);  
  57.             this.context.fillText('y: ' + rect.y + 'px', rect.x + rect.width + 5, rect.y + 22);  
  58.         },  
  59.         // 拍照  
  60.         tackPhoto() {  
  61.             this.context.drawImage(this.$refs.refVideo, 0, 0, 500, 500)  
  62.             // 保存為base64格式  
  63.             thisthis.imgUrl = this.saveAsPNG(this.$refs.refCanvas)  
  64.             var formData = new FormData();  
  65.             formData.append("file", this.imgUrl);  
  66.             this.scanTip = '登錄中,請稍等~'  
  67.             axios({  
  68.                 method: 'post',  
  69.                 url: '/faceDiscern', 
  70.                 data: formData,  
  71.             }).then(function (response) {  
  72.                 alert(response.data.data);  
  73.                 window.location.href="http://127.0.0.1:8081/home" 
  74.             }).catch(function (error) {  
  75.                 console.log(error);  
  76.             });  
  77.             this.close()  
  78.         },  
  79.         // 保存為png,base64格式圖片  
  80.         saveAsPNG(c) {  
  81.             return c.toDataURL('image/png', 0.3)  
  82.         },  
  83.         // 關(guān)閉并清理資源  
  84.         close() {  
  85.             this.flag = false  
  86.             this.tipFlag = false  
  87.             this.showContainer = false  
  88.             this.tracker && this.tracker.removeListener('track', this.handleTracked) && tracking.track('#video', this.tracker, {camera: false});  
  89.             this.tracker = null  
  90.             this.context = null  
  91.             this.scanTip = ''  
  92.             clearTimeout(this.removePhotoID)  
  93.         }  
  94.     } 

 

人臉識別

之前也搞過一個人臉識別案例 《基于 Java 實現(xiàn)的人臉識別功能(附源碼)》 ,不過調(diào)用SDK的方式太過繁瑣,而且代碼量巨大。所以這次為了簡化實現(xiàn),改用了百度的人臉識別API,沒想到出乎意料的簡單。

別抬杠問我為啥不自己寫人臉識別工具,別問,問就是不會

在百度云注冊一個應(yīng)用 https://console.bce.baidu.com/ai/?_=1595996996657&fromai=1#/ai/face/app/list,得到 API Key和 Secret Key,為了后續(xù)獲取 token用。

 

 

百度云人臉識別的API非常友好,各種操作的 demo都寫好了,拿過來簡單改改就可以。

第一步先獲取token,這是調(diào)用百度人臉識別API的基礎(chǔ)。

 

  1. https://aip.baidubce.com/oauth/2.0/token?  
  2. grant_type=client_credentials 
  3. client_id=【百度云應(yīng)用的AK】&  
  4. client_secret=【百度云應(yīng)用的SK】 

 

接下來我們開始對圖片進(jìn)行比對,百度云提供了一個在線的人臉庫,用戶登錄我們先在人臉庫查詢?nèi)讼袷欠翊嬖冢嬖趧t表示登錄成功,如果不存在則注冊到人臉庫。每個圖片有一個唯一標(biāo)識face_token。

百度人臉識別 API 實現(xiàn)比較簡單,需要特別注意參數(shù)image_type,它有三種類型

  • BASE64:圖片的base64值,base64編碼后的圖片數(shù)據(jù),編碼后的圖片大小不超過2M;
  • URL:圖片的 URL地址( 可能由于網(wǎng)絡(luò)等原因?qū)е孪螺d圖片時間過長);
  • FACE_TOKEN:人臉圖片的唯一標(biāo)識,調(diào)用人臉檢測接口時,會為每個人臉圖片賦予一個唯一的

FACE_TOKEN,同一張圖片多次檢測得到的FACE_TOKEN是同一個。

而我們這里使用的是圖片BASE64文件,所以image_type要設(shè)置成BASE64。 

  1. @Override  
  2.   public BaiDuFaceSearchResult faceSearch(String file) {  
  3.       try {  
  4.           byte[] decode = Base64.decode(Base64Util.base64Process(file));  
  5.           String faceFile = Base64Util.encode(decode);  
  6.           Map<String, Object> map = new HashMap<>();  
  7.           map.put("image", faceFile);  
  8.           map.put("liveness_control", "NORMAL");  
  9.           map.put("group_id_list", "user");  
  10.           map.put("image_type", "BASE64");  
  11.           map.put("quality_control", "LOW");  
  12.           String param = GsonUtils.toJson(map);  
  13.           String result = HttpUtil.post(faceSearchUrl, this.getAccessToken(), "application/json", param);  
  14.           BaiDuFaceSearchResult searchResult = JSONObject.parseObject(result, BaiDuFaceSearchResult.class);  
  15.           log.info(" faceSearch: {}", JSON.toJSONString(searchResult));  
  16.           return searchResult;  
  17.       } catch (Exception e) {  
  18.           log.error("get faceSearch error {}", e.getStackTrace());  
  19.           e.getStackTrace();  
  20.       }  
  21.       return null; 
  22.   }  
  23.   @Override  
  24.   public BaiDuFaceDetectResult faceDetect(String file) {  
  25.       try {  
  26.           byte[] decode = Base64.decode(Base64Util.base64Process(file));  
  27.           String faceFile = Base64Util.encode(decode);  
  28.           Map<String, Object> map = new HashMap<>();  
  29.           map.put("image", faceFile);  
  30.           map.put("face_field", "faceshape,facetype");  
  31.           map.put("image_type", "BASE64");  
  32.           String param = GsonUtils.toJson(map);  
  33.           String result = HttpUtil.post(faceDetectUrl, this.getAccessToken(), "application/json", param);  
  34.           BaiDuFaceDetectResult detectResult = JSONObject.parseObject(result, BaiDuFaceDetectResult.class);  
  35.           log.info(" detectResult: {}", JSON.toJSONString(detectResult));  
  36.           return detectResult;  
  37.       } catch (Exception e) {  
  38.           log.error("get faceDetect error {}", e.getStackTrace());  
  39.           e.getStackTrace();  
  40.       }  
  41.       return null;  
  42.   }  
  43.   @Override  
  44.   public BaiDuFaceAddResult addFace(String file, UserFaceInfo userFaceInfo) {  
  45.       try {  
  46.           byte[] decode = Base64.decode(Base64Util.base64Process(file));  
  47.           String faceFile = Base64Util.encode(decode);  
  48.           Map<String, Object> map = new HashMap<>();  
  49.           map.put("image", faceFile);  
  50.           map.put("group_id", "user");  
  51.           map.put("user_id", userFaceInfo.getUserId());  
  52.           map.put("user_info", JSON.toJSONString(userFaceInfo));  
  53.           map.put("liveness_control", "NORMAL");  
  54.           map.put("image_type", "BASE64");  
  55.           map.put("quality_control", "LOW");  
  56.           String param = GsonUtils.toJson(map);  
  57.           String result = HttpUtil.post(addfaceUrl, this.getAccessToken(), "application/json", param);  
  58.           BaiDuFaceAddResult addResult = JSONObject.parseObject(result, BaiDuFaceAddResult.class);  
  59.           log.info("addResult: {}", JSON.toJSONString(addResult));  
  60.           return addResult;  
  61.       } catch (Exception e) {  
  62.           log.error("get addFace error {}", e.getStackTrace());  
  63.           e.getStackTrace();  
  64.       }  
  65.       return null;  
  66.   }  

項目是前后端分離的,但為了大家學(xué)習(xí)方便,我把人臉識別頁面整合到了后端項目。

最后 run FireControllerApplication 訪問地址:http://localhost:8082/face 即可。

 

責(zé)任編輯:龐桂玉 來源: segmentfault
相關(guān)推薦

2014-06-18 09:32:30

編程語言Caml

2011-05-31 13:41:00

C語言

2011-06-29 09:38:13

電子書平板電腦Kindle

2012-06-04 11:51:31

飛視美視頻會議

2025-03-03 00:00:00

DeepSeek算法ignore

2021-02-03 15:29:44

人工智能人臉識別

2014-07-01 17:48:24

開發(fā)技術(shù)周刊

2022-05-18 09:49:26

MySQLID數(shù)據(jù)庫

2021-03-15 08:13:19

JavaScript開發(fā)代碼

2021-05-20 11:41:07

RSAC 2021/數(shù)

2022-07-12 08:43:31

人臉識別算法BlazeFace

2013-10-30 16:49:06

Windows XPWindows 8

2021-03-09 09:20:09

人臉識別人工智能智能手機

2020-10-10 09:01:54

泄漏

2024-09-09 09:20:00

2021-05-10 11:08:00

人工智能人臉識別

2021-02-26 01:01:05

自動化AI人工智能

2010-06-29 10:59:44

Windows 8人臉識別

2020-11-20 10:32:26

云計算云存儲

2022-04-11 15:44:07

Linux人臉識別
點贊
收藏

51CTO技術(shù)棧公眾號