当前位置:网站首页>PHP实现微信小程序人脸识别刷脸登录功能
PHP实现微信小程序人脸识别刷脸登录功能
2022-07-07 14:07:00 【全栈程序员站长】
首先我们先确认我们的百度云人脸库里已经上传了我们的个人信息照片
然后我们在后台写刷脸登陆的接口login我们要把拍照获取的照片存储到服务器
public function login(){
// 上传文件路径
$dir = "./Uploads/temp/";
if(!file_exists($dir)){
mkdir($dir,0777,true);
}
$upload = new \Think\Upload();
$upload->maxSize = 2048000 ;// 设置附件上传大小
$upload->exts = array('jpg', 'gif', 'png', 'jpeg');// 设置附件上传类型
$upload->savepath = '';
$upload->autoSub = false;
$upload->rootPath = $dir; // 设置附件上传根目录
// 上传单个文件
$info = $upload->uploadOne($_FILES['file']);
if(!$info) {
// 上传错误提示错误信息
echo json_encode(array('error'=>true,'msg'=>$upload->getError()),JSON_UNESCAPED_UNICODE);
}else{
// 上传成功 获取上传文件信息
$file = $dir . $info['savepath'].$info['savename'];
$image = base64_encode(file_get_contents($file));
$client = $this->init_face();
$options['liveness_control'] = 'NORMAL';
$options['max_user_num'] = '1';
$ret = $client->search($image,'BASE64','student',$options);
// echo json_encode($ret,JSON_UNESCAPED_UNICODE);
// exit;
if($ret['error_code']==0){
$user = $ret['result']['user_list'][0];
$no = $user['user_id'];
$score = $user['score'];
if($score>=95){
$data = M('student')->where("no = '{$no}'")->find();
$data['score'] = $score;
// $data['name'] = json_decode($data['name'],true);
// $data['sex'] = json_decode($data['sex'],true);
echo '识别成功' . json_encode($data,JSON_UNESCAPED_UNICODE);
}else{
echo '识别失败' . $data['score'];
}
}
}
}然后进行前台设计
<camera device-position="{
{device?'back':'front'}}" flash="off" binderror="error" style="width: 100%; height: 300px;"></camera>
<view class="weui-cells__title" >开关</view>
<view class="weui-cells weui-cells_after-title">
<view class="weui-cell weui-cell_switch">
<view class="weui-cell__bd">切换摄像头</view>
<view class="weui-cell__ft" >
<switch bindtap="devicePosition" />
</view>
</view>
</view>
<button type="primary" bindtap="takePhoto">刷脸登录</button>我们还可以控制相机的前后镜头
devicePosition() {
this.setData({
device: !this.data.device,
})
console.log("当前相机摄像头为:", this.data.device ? "后置" : "前置");
camera() {
let { ctx, type, startRecord } = this.data; },
data: {
src: null,
},在js里面调用接口
takePhoto() {
const ctx = wx.createCameraContext()
ctx.takePhoto({
quality: 'high',
success: (res) => {
this.setData({
src: res.tempImagePath
})
console.log(res)
wx.uploadFile({
url: '', //仅为示例,非真实的接口地址
filePath: this.data.src,
name: 'file',
formData: {
},
success: function (res) {
// var data = res.data
// var json = JSON.parse(data)
console.log(res)
wx.showModal({
title: "提示",
content: res.data,
showCancel: false,
confirmText: "确定"
})
}
})
}
})
},刷脸登录就成功了
发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/113179.html原文链接:https://javaforall.cn
边栏推荐
- Three. JS introductory learning notes 11:three JS group composite object
- 安科瑞电网智能化发展的必然趋势电力系统采用微机保护装置是
- Learn good-looking custom scroll bars in 1 minute
- nodejs package. JSON version number ^ and~
- SPI master rx time out中断
- Step by step monitoring platform ZABBIX
- 如何在shell中实现 backspace
- Strengthen real-time data management, and the British software helps the security construction of the medical insurance platform
- The unity vector rotates at a point
- 航运船公司人工智能AI产品成熟化标准化规模应用,全球港航人工智能/集装箱人工智能领军者CIMC中集飞瞳,打造国际航运智能化标杆
猜你喜欢

Xcode Revoke certificate
![[flower carving experience] 15 try to build the Arduino development environment of beetle esp32 C3](/img/8f/ca9ab042916f68de7994d9f2124da9.jpg)
[flower carving experience] 15 try to build the Arduino development environment of beetle esp32 C3

Eye of depth (VII) -- Elementary Transformation of matrix (attachment: explanation of some mathematical models)

A wave of open source notebooks is coming

Three. JS introductory learning notes 10:three JS grid

AE learning 01: AE complete project summary

Unity3d click events added to 3D objects in the scene

谈谈 SAP iRPA Studio 创建的本地项目的云端部署问题

过度依赖补助,大客户收款难,冲刺“国产数据库第一股”的达梦后劲有多足?

Numpy -- epidemic data analysis case
随机推荐
There are many ways to realize the pause function in JS
numpy--数据清洗
修改配置文件后tidb无法启动
Enterprise log analysis system elk
谈谈 SAP iRPA Studio 创建的本地项目的云端部署问题
无线传感器网络--ZigBee和6LoWPAN
A link opens the applet code. After compilation, it is easy to understand
UE4 exports the picture + text combination diagram through ucanvasrendertarget2d
SPI master RX time out interrupt
How to implement backspace in shell
Strengthen real-time data management, and the British software helps the security construction of the medical insurance platform
航運船公司人工智能AI產品成熟化標准化規模應用,全球港航人工智能/集裝箱人工智能領軍者CIMC中集飛瞳,打造國際航運智能化標杆
10 schemes to ensure interface data security
Three. JS introduction learning notes 12: the model moves along any trajectory line
hellogolang
Please supervise the 2022 plan
You Yuxi, coming!
Numpy --- basic learning notes
Three. JS introductory learning notes 08:orbitcontrols JS plug-in - mouse control model rotation, zoom in, zoom out, translation, etc
Unity3D_ Class fishing project, control the distance between collision walls to adapt to different models