亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

PHP實現(xiàn)百度人臉識別

 更新時間:2019年05月06日 10:36:52   作者:CyborgLin  
這篇文章主要為大家詳細介紹了PHP實現(xiàn)百度人臉識別,具有一定的參考價值,感興趣的小伙伴們可以參考一下

PHP接入百度人臉識別,供大家參考,具體內(nèi)容如下

1.注冊百度開發(fā)者賬號。

https://login.bce.baidu.com/?account= 注冊登錄成功后,進入控制臺,在左邊的導航欄找到產(chǎn)品-》人工智能-》人臉識別:

創(chuàng)建應用。創(chuàng)建應用成功后拿到應用的API Key和Secret Key

2.接口調(diào)用-獲取access token

調(diào)用人臉識別接口前需要獲取access token,示例代碼:

function execCurl($url, $param) {
 if (empty($url) || empty($param)) {
  return array('result' => false, 'err_msg' => 'url or param is null');
 }
 $curl = curl_init();//初始化curl
 curl_setopt($curl, CURLOPT_URL, $url);//抓取指定網(wǎng)頁
 curl_setopt($curl, CURLOPT_HEADER, 0);//設置header
 curl_setopt($curl, CURLOPT_RETURNTRANSFER, 1);//要求結(jié)果為字符串且輸出到屏幕上
 curl_setopt($curl, CURLOPT_POST, 1);//post提交方式
 curl_setopt($curl, CURLOPT_POSTFIELDS, $param);
 curl_setopt($curl, CURLOPT_SSL_VERIFYPEER, 0);
 curl_setopt($curl, CURLOPT_SSL_VERIFYHOST, 0);
 $data = curl_exec($curl);//運行curl
 $curl_err_msg = curl_error($curl);
 curl_close($curl);
 if($data === false) {
  return array('result' => false, 'err_msg' => $curl_err_msg);
 }else {
  return array('result' => true, 'data' => $data);
 }
}
 
$url = 'https://aip.baidubce.com/oauth/2.0/token';
$param = array(
 'grant_type' => 'client_credentials',
 'client_id' => '你的API Key',
 'client_secret' => '你的Secret Key'
);
$result = execCurl($url, $param);

3.調(diào)用人臉檢查接口

如果需要判斷一張圖片中的人臉,是否符合后續(xù)識別或者對比的條件,在請求時在face_field參數(shù)中請求quality。

下面示例是請求圖文為base64轉(zhuǎn)碼字符串(轉(zhuǎn)碼不能包含頭信息),也可以傳圖片網(wǎng)絡地址,官方文檔

示例代碼:

function checkPictureToCheckFace($image_path, $access_token) {
 $url = 'https://aip.baidubce.com/rest/2.0/face/v3/detect?access_token=' . $access_token;
 $param = array(
  'image' => base64EncodeImage($image_path),
  'image_type' => 'BASE64',
  'face_field' => 'quality'
 );
 $param = json_encode($param);
 $result = execCurl($url, $param);
 if($result['result'] == false) return $result;
 $data = json_decode($result['data'], true);
 if($data['error_code'] != 0) return array('result' => false, 'err_msg' => '上傳的人臉不符合要求,請重新上傳五官清晰的真實頭像');
 $err_result = array('result' => false, 'err_msg' => '上傳的人臉不符合要求,請重新上傳五官清晰的真實頭像!');
 $quality = $data['result']['face_list'][0]['quality'];
 if($quality['occlusion']['left_eye'] > 0.6) return $err_result; // 左眼被遮擋的閾值
 if($quality['occlusion']['right_eye'] > 0.6) return $err_result; // 右眼被遮擋的閾值
 if($quality['occlusion']['nose'] > 0.7) return $err_result; // 鼻子被遮擋的閾值
 if($quality['occlusion']['mouth'] > 0.7) return $err_result; // 嘴巴被遮擋的閾值
 if($quality['occlusion']['left_cheek'] > 0.8) return $err_result; // 左臉頰被遮擋的閾值
 if($quality['occlusion']['right_cheek'] > 0.8) return $err_result; // 右臉頰被遮擋的閾值
 if($quality['occlusion']['chin_contour'] > 0.6) return $err_result; // 下巴被遮擋閾值
 if($quality['blur'] != 0 && $quality['blur'] > 0.7) return $err_result; // 模糊度范圍 0是最清晰,1是最模糊
 if($quality['illumination'] < 40) return $err_result; // 光照范圍 
 if($quality['completeness'] == 0) return $err_result; // 人臉完整度 0為人臉溢出圖像邊界,1為人臉都在圖像邊界內(nèi)
 return array('result' => true);
}
 
function execCurl($url, $param) {
 if (empty($url) || empty($param)) {
  return array('result' => false, 'err_msg' => 'url or param is null');
 }
 $curl = curl_init();//初始化curl
 curl_setopt($curl, CURLOPT_URL, $url);//抓取指定網(wǎng)頁
 curl_setopt($curl, CURLOPT_HEADER, 0);//設置header
 curl_setopt($curl, CURLOPT_RETURNTRANSFER, 1);//要求結(jié)果為字符串且輸出到屏幕上
 curl_setopt($curl, CURLOPT_POST, 1);//post提交方式
 curl_setopt($curl, CURLOPT_POSTFIELDS, $param);
 curl_setopt($curl, CURLOPT_SSL_VERIFYPEER, 0);
 curl_setopt($curl, CURLOPT_SSL_VERIFYHOST, 0);
 $data = curl_exec($curl);//運行curl
 $curl_err_msg = curl_error($curl);
 curl_close($curl);
 if($data === false) {
  return array('result' => false, 'err_msg' => $curl_err_msg);
 }else {
  return array('result' => true, 'data' => $data);
 }
}
 
function base64EncodeImage($image_path) {
 $base64_image = '';
 $image_info = getimagesize($image_path);
 $image_data = fread(fopen($image_path, 'r'), filesize($image_path));
 $base64_image = chunk_split(base64_encode($image_data));
 return $base64_image;
}
 
$image_path = 'image/1.jpg';
$access_token = '上一步的獲取access token';
$result = checkPictureToCheckFace($image_path, $access_token);

判斷是否符合人臉識別檢查的字段說明:

以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

相關文章

  • 初識ThinkPHP控制器

    初識ThinkPHP控制器

    這篇文章主要帶大家了解ThinkPHP控制器的基本定義、基本操作,配置ACTION_SUFFIX,感興趣的小伙伴們可以參考一下
    2016-04-04
  • php 服務端集成支付寶APP支付實例

    php 服務端集成支付寶APP支付實例

    下面小編就為大家分享一篇php 服務端集成支付寶APP支付實例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-03-03
  • 學習PHP Cookie處理函數(shù)

    學習PHP Cookie處理函數(shù)

    這篇文章主要為大家詳細介紹了PHP Cookie處理函數(shù)的使用方法,感興趣的小伙伴們可以參考一下
    2016-08-08
  • PHP中的empty、isset、isnull的區(qū)別與使用實例

    PHP中的empty、isset、isnull的區(qū)別與使用實例

    今天小編就為大家分享一篇關于PHP中的empty、isset、isnull的區(qū)別與使用實例,小編覺得內(nèi)容挺不錯的,現(xiàn)在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧
    2019-03-03
  • php中file_exists函數(shù)使用詳解

    php中file_exists函數(shù)使用詳解

    本文給大家講解的是php中判斷文件或者目錄是否存在的file_exists函數(shù),附上幾個經(jīng)典示例,有需要的小伙伴可以參考下。
    2015-05-05
  • 詳解php偽造Referer請求反盜鏈資源

    詳解php偽造Referer請求反盜鏈資源

    這篇文章主要介紹了詳解php偽造Referer請求反盜鏈資源,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2019-01-01
  • php xml留言板 xml存儲數(shù)據(jù)的簡單例子

    php xml留言板 xml存儲數(shù)據(jù)的簡單例子

    php xml留言板 xml存儲數(shù)據(jù)的簡單例子 php操作xml的簡單留言板,帶分頁,僅供參考
    2009-08-08
  • ajax實現(xiàn)無刷新分頁(php)

    ajax實現(xiàn)無刷新分頁(php)

    直接給出源代碼,可自行分析,寫的不好請留言指正,謝謝!
    2010-07-07
  • 利用Laravel生成Gravatar頭像地址的優(yōu)雅方法

    利用Laravel生成Gravatar頭像地址的優(yōu)雅方法

    Gravatar是一圖像跟隨著您到訪過的網(wǎng)站,當您在博客中留言或發(fā)表文章,它將會出現(xiàn)在您的名稱旁。下面這篇文章主要給大家介紹了關于利用Laravel如何生成 Gravatar 頭像地址的優(yōu)雅方法,需要的朋友可以參考下。
    2017-12-12
  • yii操作cookie實例簡介

    yii操作cookie實例簡介

    這篇文章主要介紹了yii操作cookie實例,需要的朋友可以參考下
    2014-07-07

最新評論