目录

一、需求

二、准备工作

1、申请服务

2、创建应用,获取开发密钥

3、官方开发文档

4、测试人像图片

三、PHP接入

1、鉴权,获取access_token

2、人脸对比

四、完整代码


一、需求

现在人脸识别、人脸对比技术越来越成熟,使用越来越广泛,比较好的是百度AI开放平台提供的人脸对比接口,对接简单,那么怎样通过PHP来接入人脸识别的接口,以实现人脸识别呢?本篇文章详细介绍PHP接入百度AI人脸识别PAI的全步骤。

二、准备工作

因为使用的是百度AI开放平台的人脸识别接口,就需要进入到百度开放平台注册/登录平台,创建人脸对比应用,获取AIP Key和Secret Key。

1、申请服务

进入百度开放平台,找到“开放能力->人脸与人体->人脸对比”服务,立即申请使用。

地址:人脸对比_人脸对比识别_人脸对比相似度-百度AI开放平台

2、创建应用,获取开发密钥

登录平台后进入控制台,点击左上角菜单,搜索并选择“人脸识别”,点击右侧菜单应用列表,创建应用,勾选“人脸对比V3”,立即创建,创建成功后会有PAI key和Secret Key。

详细接入说明:https://ai.baidu.com/ai-doc/REFERENCE/Ck3dwjgn3

3、官方开发文档

每个用户都有一定的免费测试额度,个人认证的账号与企业认证的账号免费额度也不同。人脸识别接口有V2、V3、V4三个版本,由于我是个人认证的账号,所以使用的是V3版本。

V3版本开发文档:https://ai.baidu.com/ai-doc/FACE/Lk37c1tpf

V4版本开发文档:https://ai.baidu.com/ai-doc/FACE/Oktmssfse

4、测试人像图片

准备几张用于测试的人像图片

三、PHP接入

1、鉴权,获取access_token

接口描述:获取access_token

 名称说明
接口名称鉴权,获取access_token
接口地址https://aip.baidubce.com/oauth/2.0/token
请求方式GET/POST(推荐)
官方文档https://ai.baidu.com/ai-doc/REFERENCE/Ck3dwjhhu

 请求参数说明

参数类型必填含义说明
grant_typestring固定为client_credentialsclient_credentials 
client_idstring应用的API Key,获取方式:https://ai.baidu.com/ai-doc/REFERENCE/Ck3dwjgn3Va5yQRHlA4Fq5eR3LT0vuXV4
client_secretstring应用的Secret Key,获取方式:https://ai.baidu.com/ai-doc/REFERENCE/Ck3dwjgn30rDSjzQ20XUj5itV6WRtznPQSzr5pVw2

返回参数说明

名称类型含义
access_tokenstring要获取的Access Token
refresh_tokenstring该参数忽略
expires_instringAccess Token的有效期(秒为单位,有效期30天)
scopestring该参数忽略
session_keystring该参数忽略
session_secretstring该参数忽略

 代码示例

// 鉴权,获取token
public function getToken()
{$apiUrl = 'https://aip.baidubce.com/oauth/2.0/token';$params = ["grant_type" => 'client_credentials','client_id' => $this->api_key,"client_secret" => $this->secret_key,];$params = http_build_query($params);$result = $this->returnArray($this->freeApiCurl($apiUrl,$params));$access_token = $result['access_token'];return $access_token;
}

2、人脸对比

接口描述:人脸对比V3,对比两张图片中的人脸的相似度,并返回相似度分值。

 名称说明
接口名称人脸对比
接口地址https://aip.baidubce.com/rest/2.0/face/v3/match
请求方式POST
官方文档https://ai.baidu.com/ai-doc/FACE/Lk37c1tpf

 请求参数说明

参数类型必填含义
imagestring图片信息(总数据大小应小于10M,图片尺寸在1920x1080以下),图片上传方式根据image_type来判断。 两张图片通过json格式上传,格式参考本表格下方的示例
image_typestring图片类型
BASE64:(推荐)图片的base64值,base64编码后的图片数据,编码后的图片大小不超过2M;
FACE_TOKEN: 人脸图片的唯一标识,调用人脸检测接口时,会为每个人脸图片赋予一个唯一的FACE_TOKEN,同一张图片多次检测得到的FACE_TOKEN是同一个。
face_typestring人脸的类型
LIVE:表示生活照:通常为手机、相机拍摄的人像图片、或从网络获取的人像图片等,
IDCARD:表示身份证芯片照:二代身份证内置芯片中的人像照片,
WATERMARK:表示带水印证件照:一般为带水印的小图,如公安网小图
CERT:表示证件照片:如拍摄的身份证、工卡、护照、学生证等证件图片
INFRARED 表示红外照片:使用红外相机拍摄的照片
HYBRID:表示混合类型,如果传递此值时会先对图片进行检测判断所属类型(生活照 or 证件照)(仅针对请求参数 image_type 为 BASE64 或 URL 时有效)
默认LIVE
quality_controlstring图片质量控制
NONE: 不进行控制
LOW:较低的质量要求
NORMAL: 一般的质量要求
HIGH: 较高的质量要求
默认 NONE
若图片质量不满足要求,则返回结果中会提示质量检测失败
liveness_controlstring活体检测控制
NONE: 不进行控制
LOW:较低的活体要求(高通过率 低攻击拒绝率)
NORMAL: 一般的活体要求(平衡的攻击拒绝率, 通过率)
HIGH: 较高的活体要求(高攻击拒绝率 低通过率)
默认 NONE
若活体检测结果不满足要求,则返回结果中会提示活体检测失败
face_sort_typestring人脸检测排序类型
0:代表检测出的人脸按照人脸面积从大到小排列
1:代表检测出的人脸按照距离图片中心从近到远排列
默认为0
spoofing_controlstring合成图控制参数
NONE: 不进行控制
LOW:较低的合成图阈值数值,由于合成图判定逻辑为大于阈值视为合成图攻击,该项代表低通过率、高攻击拒绝率
NORMAL: 一般的合成图阈值数值,由于合成图判定逻辑为大于阈值视为合成图攻击,该项代表平衡的攻击拒绝率, 通过率
HIGH: 较高的合成图阈值数值,由于合成图判定逻辑为大于阈值视为合成图攻击,该项代表高通过率、低攻击拒绝率
默认为NONE

返回参数说明

名称类型含义
scorefloat要获取的Access Token
face_listarray人脸信息列表,列表里的face_token顺序与传入的图片顺序保存一致
face_tokenstring人脸的唯一标志

质量控制参数说明:不同的控制度下所对应的质量控制阈值,如果检测出来的质量信息某一项不符合控制阈值的要求,则会返回错误信息。

控制参数说明文档:https://ai.baidu.com/ai-doc/FACE/Lk37c1tpf 

 代码示例

public function run()
{$img1 = 'static/index/images/11.png';$img2 = 'static/index/images/22.png';// 读取图片文件内容$imageContent1 = file_get_contents($img1);$imageContent2 = file_get_contents($img2);// 将图片内容转换为Base64编码$base64Image1 = base64_encode($imageContent1);$base64Image2 = base64_encode($imageContent2);$apiUrl = 'https://aip.baidubce.com/rest/2.0/face/v3/match?access_token='.$this->getToken();$params = [['image' => $base64Image1,'image_type' => 'BASE64','face_type' => 'LIVE',          // 人脸的类型'quality_control' => 'HIGH',    // 图片质量控制'liveness_control' => 'NONE'    // 活体检测控制],['image' => $base64Image2,'image_type' => 'BASE64','face_type' => 'LIVE',          // 人脸的类型'quality_control' => 'HIGH',    // 图片质量控制'liveness_control' => 'NONE'    // 活体检测控制]];// 参数 数组格式转json格式$params = json_encode($params);$result = $this->returnArray($this->freeApiCurl($apiUrl,$params,1));}

 需要注意的几点

1、access_token的有效期为30天,切记需要每30天进行定期更换,或者每次请求都拉取新token;

2、请求参数是json,不是数组,在传入之前先转成json格式;

3、传入的图片(image字段)大小不超过10M,尺寸在1920*1080以下,必须是base64编码,且不包含图片头,如data:image/jpg;base64,使用前请检查一边;

4、图片格式先仅支持png、jpg、jpeg、bmp格式;

5、人脸类型、图片质量控制、活体检测控制设置不同的阈值也会返回不同的结果或错误,错误可参看错误码,所以需要根据实际需求设置阈值。

四、完整代码

使用ThinkPHP5框架,替换自己的api_key和secret_key即可。

<?php
namespace app\index\controller;
use think\Controller;class Face extends Controller
{private $api_key = 'xxxxxx';private $secret_key = 'xxxxxxx';// 鉴权,获取tokenpublic function getToken(){$apiUrl = 'https://aip.baidubce.com/oauth/2.0/token';$params = ["grant_type" => 'client_credentials','client_id' => $this->api_key,"client_secret" => $this->secret_key,];$params = http_build_query($params);$result = $this->returnArray($this->freeApiCurl($apiUrl,$params));$access_token = $result['access_token'];return $access_token;}public function run(){$img1 = 'static/index/images/11.png';$img2 = 'static/index/images/22.png';// 读取图片文件内容$imageContent1 = file_get_contents($img1);$imageContent2 = file_get_contents($img2);// 将图片内容转换为Base64编码$base64Image1 = base64_encode($imageContent1);$base64Image2 = base64_encode($imageContent2);$apiUrl = 'https://aip.baidubce.com/rest/2.0/face/v3/match?access_token='.$this->getToken();$params = [['image' => $base64Image1,'image_type' => 'BASE64','face_type' => 'LIVE',		// 人脸的类型'quality_control' => 'HIGH',	// 	图片质量控制'liveness_control' => 'NONE'	// 活体检测控制],['image' => $base64Image2,'image_type' => 'BASE64','face_type' => 'LIVE',		// 人脸的类型'quality_control' => 'HIGH',	// 	图片质量控制'liveness_control' => 'NONE'	// 活体检测控制]];// 参数 数组格式转json格式$params = json_encode($params);$result = $this->returnArray($this->freeApiCurl($apiUrl,$params,1));}/*** 将JSON内容转为数组,并返回*/public function returnArray($content){return json_decode($content,true);}/*** @describe CURL操作,支持POST和GET两种请求方式* @param $url:API接口请求地址,$param:请求参数,$ispost:请求方式 post=1/get=2* @return array  接口返回结果集*/public function freeApiCurl($url,$params=false,$ispost=0){$ch = curl_init();curl_setopt( $ch, CURLOPT_HTTP_VERSION , CURL_HTTP_VERSION_1_1 );curl_setopt( $ch, CURLOPT_HTTP_VERSION , CURL_HTTP_VERSION_1_1 );curl_setopt( $ch, CURLOPT_CONNECTTIMEOUT , 60 );curl_setopt( $ch, CURLOPT_TIMEOUT , 60);curl_setopt( $ch, CURLOPT_RETURNTRANSFER , true );if( $ispost ){curl_setopt( $ch , CURLOPT_POST , true );curl_setopt( $ch , CURLOPT_POSTFIELDS , $params );curl_setopt( $ch , CURLOPT_URL , $url );}else{if($params){curl_setopt( $ch , CURLOPT_URL , $url.'?'.$params );}else{curl_setopt( $ch , CURLOPT_URL , $url);}}$response = curl_exec( $ch );if ($response === FALSE) {return false;}curl_close( $ch );return $response;}}

返回结果

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:http://www.pswp.cn/news/917138.shtml
繁体地址,请注明出处:http://hk.pswp.cn/news/917138.shtml
英文地址,请注明出处:http://en.pswp.cn/news/917138.shtml

如若内容造成侵权/违法违规/事实不符,请联系英文站点网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【东枫科技】DreamHAT+

DreamHAT 是一款顶部附加硬件 (HAT) 套件&#xff0c;可为 Raspberry Pi 提供 60GHz 毫米波雷达供您使用。 全尺寸 HAT 包含一个英飞凌 BGT60TR13C 芯片&#xff0c;具有单个发射天线和三个接收器&#xff08;TX/RX&#xff09;&#xff0c;通过 GPIO 引脚和 SPI 连接到 Raspbe…

Spring Boot + MongoDB:从零开始手动配置 MongoConfig 实战

前言 你以为只要写上 spring.data.mongodb.*,就能一劳永逸,MongoDB 立马听话?别天真,这只是入门级操作,像是拿个自动挡钥匙,开个小车溜达溜达,远远算不上高手操作。当项目需求变得复杂,连接字符串需要灵活配置,或者多数据源并行作战时,自动配置的魔法显得捉襟见肘。…

建筑节能目标下,楼宇自控系统以高效运行助力节能减碳

随着全球气候变化问题日益严峻&#xff0c;节能减排已成为各国政府和企业的重要任务。在建筑领域&#xff0c;楼宇自控系统&#xff08;Building Automation System, BAS&#xff09;作为实现建筑节能目标的关键技术&#xff0c;正发挥着越来越重要的作用。根据中国政府发布的《…

LOVON——面向足式Open-Vocabulary的VLN导航:LLM做任务分解、YOLO11做目标检测,最后L2MM将指令和视觉映射为动作,且解决动态模糊

前言 因为项目需要(比如我们在做的两个展厅讲解订单)&#xff0c;近期我一直在研究VLN相关&#xff0c;有些工作哪怕暂时还没开源(将来可能会开源)&#xff0c;但也依然会解读&#xff0c;比如好处之一是构建完整的VLN知识体系&#xff0c;本文便是其中一例 我在解读过程中&am…

在线免费的AI文本转语音工具TTSMaker介绍

TTSMaker是一个在线的文本转语音工具&#xff0c; 支持多语言和中文方言&#xff0c;不同的语言和方言单次转换的字符上限从200-10000 不同&#xff0c;转换的效果还不错&#xff0c;听不出明显的AI痕迹。 工具的网址是&#xff1a;https://ttsmaker.cn/。 工具的界面如上&…

【AI问答】PromQL中interval和rate_interval的区别以及Grafana面板的配置建议

问题1&#xff1a;interval和rate_interval的区别 在PromQL中确实有 $__rate_interval 这个特殊的变量&#xff0c;它与 $__interval 有不同的用途和计算方式。 $__interval vs $__rate_interval 1. $__interval 含义&#xff1a;Grafana计算出的基本时间间隔计算方式&#xff…

STM32学习记录--Day5

今天了解了&#xff1a;中断中断有多个类别包括&#xff1a;USART中断&#xff0c;I2C中断等&#xff1b;并通过NVIC来分配中断的优先级EXTIEXTI的内部结构&#xff1a;EXTI线&#x1f527; ​​一、EXTI系统核心架构​​1. ​​中断源输入&#xff08;左上区域&#xff09;​​…

CentOS7下同步时间的几种方式(NTP 、Chrony和systemd-timesyncd)

文章目录前言一、NTP (Network Time Protocol) & ntpd1.原理2. 安装与配置(ntp 包)3.NTPd 优缺点对比二、Chrony1.原理2.安装与配置 (chrony 包)3. 优点4. 缺点三、systemd-timesyncd1.原理2.安装与配置 (systemd 自带)3. 优点4. 缺点四、手动同步工具1.ntpdate(已废弃&…

Web3:在 VSCode 中基于 Foundry 快速构建 Solidity 智能合约本地开发环境

相关文章推荐链接Web3专栏https://blog.csdn.net/qq_42392981/category_13016259.html在 VSCode 中基于 Foundry 快速构建 Solidity 智能合约本地开发环境引言1. 开发环境准备&#xff08;Windows&#xff09;1.1 安装 VSCode1.2 安装推荐插件1.3 安装 Foundry1.4 验证 Forge 和…

Implement recovery based on PITR using dump file and binlog

模拟生产场景中需要基于某个事务点的恢复&#xff0c;使用存量备份与存量binlog 生成测试数据 (rootlocalhost) [(none)]> create database NanJing; Query OK, 1 row affected (0.01 sec) (rootlocalhost) [test]> use NanJing; Database changed (rootlocalhost) [NanJ…

HTML-取消div,a等标签点击效果

一、背景当标签被设置onclick事件之后&#xff0c;在有些手机浏览器中&#xff0c;点击这些标签&#xff0c;会有点击变色效果。想要取消点击变色效果。通过为div和标签元素添加-webkit-tap-highlight-color样式属性&#xff0c;可以有效地解决这一问题二、解决方案已a标签示例…

VR 三维重建:开启沉浸式体验新时代

在科技飞速发展的今天&#xff0c;VR&#xff08;虚拟现实&#xff09;技术已经逐渐渗透到我们生活的各个领域&#xff0c;为我们带来了前所未有的沉浸式体验。而 VR 三维重建作为 VR 技术的重要应用之一&#xff0c;更是让人们能够身临其境地感受各种场景&#xff0c;无论是旅…

iTwinjs 几何 - Curve

CurvePrimitive 常用的见下 LineSegment3d直线段两点直线边、杆件、骨架LineString3d折线多点连续直线轮廓线、路径Arc3d圆弧 / 椭圆弧圆心 半径 起止角圆孔、圆角、弧段BezierCurve3d贝塞尔曲线端点 控制点平滑过渡、动画轨迹BSplineCurve3dB 样条 / NURBS控制点 节点矢…

iPhone 恢复出厂设置是否会删除所有内容?

当你的 iPhone 经常崩溃、出现黑屏死机、卡在加载屏幕上等问题时&#xff0c;你可能会考虑进行恢复出厂设置来修复它。或者在其他情况下&#xff0c;如果你要将使用多年的设备交给新主人&#xff0c;出于安全考虑&#xff0c;也需要进行恢复出厂设置。那么&#xff0c;恢复出厂…

机器学习②【字典特征提取、文本特征处理(TF-IDF)、数据标准化与归一化、特征降维】

文章目录先言一、特征工程概述二、特征提取1.字典特征提取&#xff08;特征离散化&#xff09;2.文本特征提取2.1英文文本提取2.2中文文本提取&#xff08;jieba分词器&#xff09;3.TfidfVectorizer TF-IDF文本特征词的重要程度特征提取三、数据归一化与标准化1.MinMaxScaler …

3、CC3200串口DMA

先说下CC3200存在2个16*8的fifos, 分别用于发送和接收 当fifos被disable时&#xff0c;将会作为一个1字节深度的保持寄存器&#xff0c; 所以无论fifos是开是关&#xff0c;发送和接收都绕不开fifos DMA 由于发送和接收都绕不过fifos,所以DMA也绕不开FIFOS. MAP_UARTFIFOLevelS…

从游戏NPC到手术助手:Agent AI重构多模态交互,具身智能打开AGI新大门

注&#xff1a;此文章内容均节选自充电了么创始人&#xff0c;CEO兼CTO陈敬雷老师的新书《GPT多模态大模型与AI Agent智能体》&#xff08;跟我一起学人工智能&#xff09;【陈敬雷编著】【清华大学出版社】 清华《GPT多模态大模型与AI Agent智能体》书籍配套视频课程【陈敬雷…

Lesson 29 Taxi!

Lesson 29 Taxi! taxi n.出租车 同义词:cab n.出租车 相关:taxi meter计价器 taxi stand taxi rank 出租车站 call ataxi 叫车&#xff0c;打车 例句:对不起,请问出租车站在哪里? Excuse me, do you know where the taxi rank is please? land v.着陆&#xff0c;登陆n.陆地…

怎样将allegro的brd文件转化为AD的PCB文件

由于工作需要将allegro的PCB转成ad给同事&#xff0c;在使用AD软件导入Allegro的brd格式文件时出现各种的异常报错弹窗问题&#xff0c;现分享两种将Allegro PCB文件导入到AD中的方法。一、第1种方法使用高版本的AD软件&#xff08;AD22&#xff0c;同时操作电脑需安装了Allegr…

[免费]【NLP舆情分析】基于python微博舆情分析可视化系统(flask+pandas+echarts)【论文+源码+SQL脚本】

大家好&#xff0c;我是python222_小锋老师&#xff0c;看到一个不错的【NLP舆情分析】基于python微博舆情分析可视化系统(flaskpandasecharts)&#xff0c;分享下哈。 项目视频演示 【免费】【NLP舆情分析】基于python微博舆情分析可视化系统(flaskpandasecharts爬虫) Pytho…