热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

人脸识别人脸实名认证

首先:注册百度云,并搜索人脸实名认证第二步查看自己要请求的api创建步骤:添加一个人脸识别的人脸库添加一个人脸用户组添加一个人脸用户给这

首先:
注册百度云,并搜索人脸实名认证
在这里插入图片描述
第二步查看自己要请求的api
在这里插入图片描述

创建步骤:
在这里插入图片描述
添加一个人脸识别的人脸库
在这里插入图片描述
添加一个人脸用户组
在这里插入图片描述
添加一个人脸用户
在这里插入图片描述
给这个用户添加一张人像图
在这里插入图片描述

然后 渲染出 拍照页
前端:


<html>
<head><meta charset="utf-8"><title>layuititle><meta name="renderer" content="webkit"><meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1"><meta name="viewport" content="token punctuation">"><link rel="stylesheet" href="/static/lib/layui-v2.5.4/css/layui.css" media="all"><link rel="stylesheet" href="/static/css/public.css" media="all"><script src="https://apps.bdimg.com/libs/jquery/2.1.4/jquery.min.js">script><style>*{margin: 0 auto;padding: 0;}button{width: 100px;height: 40px;background-color: black;color: white;border-radius: 10px;}#video{background-color: black;border-radius: 50%;}.layuimini-container{margin: 10%;}style>
head>
<body>
<div class="layuimini-container"><div align="center"><video id="video" width="300px" height="300px" autoplay>video><canvas hidden="hidden" id="canvas" width="626" height="800">canvas>div><div align="center"><button id="open">授权摄像头button><button id="close">关闭摄像头button><button id="CatchCode">人脸检测button>div>
div>
<script src="/static/lib/layui-v2.5.4/layui.js" charset="utf-8">script>
<script src="/static/js/wk.js" charset="utf-8">script>
<script type="text/Javascript">var video; //视频流对象var context; //绘制对象var canvas; //画布对象$(function () {var flag = false;//开启摄像头$("#open").click(function () {//判断摄像头是否打开if (!flag) {//调用摄像头初始化open();flag = true;}});//关闭摄像头$("#close").click(function () {//判断摄像头是否打开if (flag) {video.srcObject.getTracks()[0].stop();flag = false;}});//拍照$("#CatchCode").click(function () {if (flag) {context.drawImage(video, 0, 0, 330, 250);CatchCode();} elsealert("请先开启摄像头!");});});//将当前图像传输到后台function CatchCode() {//获取图像var img = getBase64();//Ajax将Base64字符串传输到后台处理$.ajax({type: "POST",async: false,url: "{:url(&#39;faceVerify&#39;)}",data: {img: img,},dataType: "JSON",success: function (data) {console.log(data);return false;//返回的结果if (data.code == 0){location.href = "{:url(&#39;paySuccess&#39;)}"}else {location.href = "{:url(&#39;payFail&#39;)}"return false;}}});};// 开启摄像头function open() {// 获取摄像头对象canvas = document.getElementById("canvas");context = canvas.getContext("2d");// 获取视频流video = document.getElementById("video");var videoObj = {"video": true},errBack = function (error) {console.log("Video capture error: ", error.code);};context.drawImage(video, 0, 0, 330, 250);if (navigator.getUserMedia || navigator.webkitGetUserMedia ||navigator.mozGetUserMedia) {navigator.getUserMedia = navigator.getUserMedia ||navigator.webkitGetUserMedia ||navigator.mozGetUserMedia;navigator.getUserMedia(videoObj, function (stream) {video.srcObject = stream;video.play();}, errBack);}}// 将摄像头拍取的图片转换为Base64格式字符串function getBase64() {// 获取当前图像并转换为Base64的字符串var imgSrc = canvas.toDataURL("image/png");// 截取字符串return imgSrc.substring(22);};
script>
body>
html>

curl请求代码:


function request_post($url = &#39;&#39;, $param = &#39;&#39;) {if (empty($url) || empty($param)) {return false;}$postUrl = $url;$curlPost = $param;$curl = curl_init();//初始化curlcurl_setopt($curl, CURLOPT_URL,$postUrl);//抓取指定网页curl_setopt($curl, CURLOPT_HEADER, 0);//设置headercurl_setopt($curl, CURLOPT_RETURNTRANSFER, 1);//要求结果为字符串且输出到屏幕上curl_setopt($curl, CURLOPT_POST, 1);//post提交方式curl_setopt($curl, CURLOPT_POSTFIELDS, $curlPost);$data = curl_exec($curl);//运行curlcurl_close($curl);return $data;}/*** 发起http post请求(REST API), 并获取REST请求的结果* @param string $url* @param string $param* @return - http response body if succeeds, else false.*/
function request_posts($url = &#39;&#39;, $param = &#39;&#39;)
{if (empty($url) || empty($param)) {return false;}$postUrl = $url;$curlPost = $param;// 初始化curl$curl = curl_init();curl_setopt($curl, CURLOPT_URL, $postUrl);curl_setopt($curl, CURLOPT_HEADER, 0);// 要求结果为字符串且输出到屏幕上curl_setopt($curl, CURLOPT_RETURNTRANSFER, 1);curl_setopt($curl, CURLOPT_SSL_VERIFYPEER, false);// post提交方式curl_setopt($curl, CURLOPT_POST, 1);curl_setopt($curl, CURLOPT_POSTFIELDS, $curlPost);// 运行curl$data = curl_exec($curl);curl_close($curl);return $data;
}

后端:
第一步:获取access_token

public function getToken(){$url = &#39;https://aip.baidubce.com/oauth/2.0/token&#39;;$post_data[&#39;grant_type&#39;] = &#39;client_credentials&#39;;$post_data[&#39;client_id&#39;] = &#39;你创建应用给的ak&#39;; // Api Key$post_data[&#39;client_secret&#39;] = &#39;你创建应用给的sk&#39;; // Secret Key$o = "";foreach ($post_data as $k => $v) {$o .= "$k=" . urlencode($v) . "&";}$post_data = substr($o, 0, -1);$res = request_post($url, $post_data);$res = json_decode($res, true);print_r( $res);cache(&#39;token&#39;,$res[&#39;access_token&#39;]);}

第二部:开始识别

public function faceVerify(Request $request){$token = cache(&#39;token&#39;);$url = &#39;https://aip.baidubce.com/rest/2.0/face/v3/search?access_token=&#39; .$token;$image = $request->param(&#39;img&#39;);$bodys = "{\"image\":\"$image\",\"image_type\":\"BASE64\",\"group_id_list\":\"face\",\"quality_control\":\"LOW\",\"liveness_control\":\"NORMAL\"}";// print_r($bodys);die;$res = request_posts($url, $bodys);$req = json_decode($res,true);$userList = $req[&#39;result&#39;][&#39;user_list&#39;][0];print_r($userList);}

大功告成!!!!!!!!!!感谢观看~~


推荐阅读
  • 在JavaWeb开发中,文件上传是一个常见的需求。无论是通过表单还是其他方式上传文件,都必须使用POST请求。前端部分通常采用HTML表单来实现文件选择和提交功能。后端则利用Apache Commons FileUpload库来处理上传的文件,该库提供了强大的文件解析和存储能力,能够高效地处理各种文件类型。此外,为了提高系统的安全性和稳定性,还需要对上传文件的大小、格式等进行严格的校验和限制。 ... [详细]
  • 深入探索HTTP协议的学习与实践
    在初次访问某个网站时,由于本地没有缓存,服务器会返回一个200状态码的响应,并在响应头中设置Etag和Last-Modified等缓存控制字段。这些字段用于后续请求时验证资源是否已更新,从而提高页面加载速度和减少带宽消耗。本文将深入探讨HTTP缓存机制及其在实际应用中的优化策略,帮助读者更好地理解和运用HTTP协议。 ... [详细]
  • 技术分享:使用 Flask、AngularJS 和 Jinja2 构建高效前后端交互系统
    技术分享:使用 Flask、AngularJS 和 Jinja2 构建高效前后端交互系统 ... [详细]
  • C++ 异步编程中获取线程执行结果的方法与技巧及其在前端开发中的应用探讨
    本文探讨了C++异步编程中获取线程执行结果的方法与技巧,并深入分析了这些技术在前端开发中的应用。通过对比不同的异步编程模型,本文详细介绍了如何高效地处理多线程任务,确保程序的稳定性和性能。同时,文章还结合实际案例,展示了这些方法在前端异步编程中的具体实现和优化策略。 ... [详细]
  • Web开发框架概览:Java与JavaScript技术及框架综述
    Web开发涉及服务器端和客户端的协同工作。在服务器端,Java是一种优秀的编程语言,适用于构建各种功能模块,如通过Servlet实现特定服务。客户端则主要依赖HTML进行内容展示,同时借助JavaScript增强交互性和动态效果。此外,现代Web开发还广泛使用各种框架和库,如Spring Boot、React和Vue.js,以提高开发效率和应用性能。 ... [详细]
  • 本文总结了一些开发中常见的问题及其解决方案,包括特性过滤器的使用、NuGet程序集版本冲突、线程存储、溢出检查、ThreadPool的最大线程数设置、Redis使用中的问题以及Task.Result和Task.GetAwaiter().GetResult()的区别。 ... [详细]
  • MySQL Decimal 类型的最大值解析及其在数据处理中的应用艺术
    在关系型数据库中,表的设计与SQL语句的编写对性能的影响至关重要,甚至可占到90%以上。本文将重点探讨MySQL中Decimal类型的最大值及其在数据处理中的应用技巧,通过实例分析和优化建议,帮助读者深入理解并掌握这一重要知识点。 ... [详细]
  • 本文介绍了如何使用 Node.js 和 Express(4.x 及以上版本)构建高效的文件上传功能。通过引入 `multer` 中间件,可以轻松实现文件上传。首先,需要通过 `npm install multer` 安装该中间件。接着,在 Express 应用中配置 `multer`,以处理多部分表单数据。本文详细讲解了 `multer` 的基本用法和高级配置,帮助开发者快速搭建稳定可靠的文件上传服务。 ... [详细]
  • 在PHP中如何正确调用JavaScript变量及定义PHP变量的方法详解 ... [详细]
  • 【实例简介】本文详细介绍了如何在PHP中实现微信支付的退款功能,并提供了订单创建类的完整代码及调用示例。在配置过程中,需确保正确设置相关参数,特别是证书路径应根据项目实际情况进行调整。为了保证系统的安全性,存放证书的目录需要设置为可读权限。值得注意的是,普通支付操作无需证书,但在执行退款操作时必须提供证书。此外,本文还对常见的错误处理和调试技巧进行了说明,帮助开发者快速定位和解决问题。 ... [详细]
  • 基于Net Core 3.0与Web API的前后端分离开发:Vue.js在前端的应用
    本文介绍了如何使用Net Core 3.0和Web API进行前后端分离开发,并重点探讨了Vue.js在前端的应用。后端采用MySQL数据库和EF Core框架进行数据操作,开发环境为Windows 10和Visual Studio 2019,MySQL服务器版本为8.0.16。文章详细描述了API项目的创建过程、启动步骤以及必要的插件安装,为开发者提供了一套完整的开发指南。 ... [详细]
  • 在处理大规模数据数组时,优化分页组件对于提高页面加载速度和用户体验至关重要。本文探讨了如何通过高效的分页策略,减少数据渲染的负担,提升应用性能。具体方法包括懒加载、虚拟滚动和数据预取等技术,这些技术能够显著降低内存占用和提升响应速度。通过实际案例分析,展示了这些优化措施的有效性和可行性。 ... [详细]
  • 深入解析Android 4.4中的Fence机制及其应用
    在Android 4.4中,Fence机制是处理缓冲区交换和同步问题的关键技术。该机制广泛应用于生产者-消费者模式中,确保了不同组件之间高效、安全的数据传输。通过深入解析Fence机制的工作原理和应用场景,本文探讨了其在系统性能优化和资源管理中的重要作用。 ... [详细]
  • ### 优化后的摘要本学习指南旨在帮助读者全面掌握 Bootstrap 前端框架的核心知识点与实战技巧。内容涵盖基础入门、核心功能和高级应用。第一章通过一个简单的“Hello World”示例,介绍 Bootstrap 的基本用法和快速上手方法。第二章深入探讨 Bootstrap 与 JSP 集成的细节,揭示两者结合的优势和应用场景。第三章则进一步讲解 Bootstrap 的高级特性,如响应式设计和组件定制,为开发者提供全方位的技术支持。 ... [详细]
  • 在PHP中实现腾讯云接口签名,以完成人脸核身功能的对接与签名配置时,需要注意将文档中的POST请求改为GET请求。具体步骤包括:使用你的`secretKey`生成签名字符串`$srcStr`,格式为`GET faceid.tencentcloudapi.com?`,确保参数正确拼接,避免因请求方法错误导致的签名问题。此外,还需关注API的其他参数要求,确保请求的完整性和安全性。 ... [详细]
author-avatar
mobiledu2502860487
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有