java 百度人臉識別介面呼叫配置
阿新 • • 發佈:2022-02-17
/**人臉識別處理中方法
* @param
* @throws Exception
*/
@RequestMapping(value="/faceRecognition")
@ResponseBody
public Object faceRecognition() throws Exception{
Map<String,Object> map = new HashMap<String,Object>();
String errInfo = "error";
PageData pd = new PageData();
pd = this.getPageData();
String imgData = pd.getString("PHOTODATA").replace("data:image/jpeg;base64,", "").replace("data:image/png;base64,", "");
String times = pd.getString("times");
String USERNAME = pd.getString("USERNAME");
pd.put("USERNAME", Tools.notEmpty(USERNAME)?USERNAME:Jurisdiction.getUsername());
PageData upd = new PageData();
upd = photoService.findFace(pd);
if("1".equals(times)) { //第一次存,第二次根據兩個base64進行頭像識別
pd.put("PHOTO", imgData); //把base64編碼存到PHOTO0欄位裡面
pd.put("STATE", "yes");
if(null == upd) {
photoService.addFace(pd);
}else {
photoService.editFace(pd);
}
errInfo = "success";
}else {
PageData tpd = new PageData();
tpd.put("USERNAME", "FaceAccessToken"); //使用者名稱為 FaceAccessToken 的在使用者頭像表SYS_USERPHOTO裡,PHOTO2 存的是更新Token的時間,PHOTO3存的是Token的值,此資料所有使用者共享
tpd = photoService.findById(tpd);
String accessToken = tpd.getString("PHOTO3");
if(DateUtil.getDaySub(tpd.getString("PHOTO2"),DateUtil.getDay()) > 29) { //access_token有過期時間為30天,過期後重新獲取。
accessToken = AuthService.getAuth();
tpd.put("PHOTO2", DateUtil.getDay());
tpd.put("PHOTO3", accessToken);
photoService.edit(tpd);
}
if(FaceMatch.getScore(upd.getString("PHOTO"),imgData,accessToken)) {
errInfo = "success";
upd.put("STATE", "yes");
photoService.editFaceState(upd);//更新識別狀態
}
}
map.put("result", errInfo);
return map;
}
package org.fh.util;
import org.json.JSONObject;
import java.io.BufferedReader;
import java.io.InputStreamReader;
import java.net.HttpURLConnection;
import java.net.URL;
import java.util.List;
import java.util.Map;
/**
* 說明:獲取百度人臉識別token類
* 作者:FH Admin
* from:fhadmin.cn
*/
public class AuthService {
/**
* 獲取許可權token
* @return 返回示例:
* {
* "access_token": "24.460da4889caad24c1ccxxdb1fea17221975.2592000.1491995545.282335-1234567",
* "expires_in": 2592000
* }
*/
public static String getAuth() {
// 官網獲取的 API Key 更新為你註冊的
String clientId = "GgNx1THTR6kScxx2cQe36jRT2a";
// 官網獲取的 Secret Key 更新為你註冊的
String clientSecret = "I0L1rNSWwIsu6zx3cxczz1hnBGDbCgrjkCvaV";
return getAuth(clientId, clientSecret);
}
/**
* 獲取API訪問token
* 該token有一定的有效期,需要自行管理,當失效時需重新獲取.
* @param ak - 百度雲官網獲取的 API Key
* @param sk - 百度雲官網獲取的 Securet Key
* @return assess_token 示例:
* "24.460da4889caad24cc23231fea17221975.259110.14e91995545.282335-1234567"
*/
public static String getAuth(String ak, String sk) {
// 獲取token地址
String authHost = "https://aip.baidubce.com/oauth/2.0/token?";
String getAccessTokenUrl = authHost
// 1. grant_type為固定引數
+ "grant_type=client_credentials"
// 2. 官網獲取的 API Key
+ "&client_id=" + ak
// 3. 官網獲取的 Secret Key
+ "&client_secret=" + sk;
try {
URL realUrl = new URL(getAccessTokenUrl);
// 開啟和URL之間的連線
HttpURLConnection connection = (HttpURLConnection) realUrl.openConnection();
connection.setRequestMethod("GET");
connection.connect();
// 獲取所有響應頭欄位
Map<String, List<String>> map = connection.getHeaderFields();
// 遍歷所有的響應頭欄位
for (String key : map.keySet()) {
System.err.println(key + "--->" + map.get(key));
}
// 定義 BufferedReader輸入流來讀取URL的響應
BufferedReader in = new BufferedReader(new InputStreamReader(connection.getInputStream()));
String result = "";
String line;
while ((line = in.readLine()) != null) {
result += line;
}
/**
* 返回結果示例
*/
JSONObject jsonObject = new JSONObject(result);
String access_token = jsonObject.getString("access_token");
return access_token;
} catch (Exception e) {
System.err.printf("獲取token失敗!");
e.printStackTrace(System.err);
}
return null;
}
}