django--调用百度AI接口实现人脸注册登录
面部识别----考勤打卡、注册登录、面部支付等等...感觉很高大上,又很方便,下面用python中的框架--django完成一个注册登录的功能,调用百度AI的接口,面部识别在网上也有好多教程,可以自己建模,训练模型,但是这都需要大量的数据去提高模型的准确度,我们直接用了百度AI的接口,十分的快捷、高效、准确,下来码一下代码啦!!
首先需要在百度AI官网注册一个应用,免费,并提供强大的人脸库。
1.注册表单
<div class="tab-content">
<div class="tab-content-inner active" data-content="signup">
<!-- <form action="{% url 'regist' %}" method="POST"> -->
<div class="row form-group">
<div class="col-md-12">
<input type="text" class="form-control" id="username" placeholder="用户名">
</div>
</div>
<div class="row form-group">
<div class="col-md-12">
<input type="text" class="form-control" id="mobile" placeholder="手机号">
</div>
</div>
<div class="row form-group">
<div class="col-md-12">
<input type="password" class="form-control" id="password" placeholder="密码">
</div>
</div>
<div class="row form-group">
<div class="col-md-12">
<!-- <input type="text" class="form-control" id="mobile_code" placeholder="验证码">
<input type="button" value=" 获取验证码" id="zphone"> -->
</div>
</div>
<div class="row form-group">
<div class="col-md-12">
<label for="password2"><font color='green'>新用户点击注册会有面部特征收集哦!</font></label>
</div>
</div> <div class="row form-group">
<div class="col-md-12">
<input type="submit" class="btn btn-primary" value="注册" id="regist">
</div>
</div>
<!-- </form> -->
</div>
2.注册时调用摄像头,ajax封装给后端的数据
<script>
!(function () {
// 老的浏览器可能根本没有实现 mediaDevices,所以我们可以先设置一个空的对象
if (navigator.mediaDevices === undefined) {
navigator.mediaDevices = {};
}
if (navigator.mediaDevices.getUserMedia === undefined) {
navigator.mediaDevices.getUserMedia = function (constraints) {
// 首先,如果有getUserMedia的话,就获得它
var getUserMedia = navigator.webkitGetUserMedia || navigator.mozGetUserMedia || navigator.msGetUserMedia; // 一些浏览器根本没实现它 - 那么就返回一个error到promise的reject来保持一个统一的接口
if (!getUserMedia) {
return Promise.reject(new Error('getUserMedia is not implemented in this browser'));
} // 否则,为老的navigator.getUserMedia方法包裹一个Promise
return new Promise(function (resolve, reject) {
getUserMedia.call(navigator, constraints, resolve, reject);
});
}
}
const constraints = {
video: true,
audio: false
};
videoPlaying = false;
v = document.getElementById('v');
promise = navigator.mediaDevices.getUserMedia(constraints);
promise.then(stream => {
// 旧的浏览器可能没有srcObject
if ("srcObject" in v) {
v.srcObject = stream;
} else {
// 防止再新的浏览器里使用它,应为它已经不再支持了
v.src = window.URL.createObjectURL(stream);
}
v.onloadedmetadata = function (e) {
v.play();
videoPlaying = true;
};
}).catch(err => {
console.error(err.name + ": " + err.message);
})
document.getElementById('regist').addEventListener('click', function () {
if (videoPlaying) {
mycanvas = document.getElementById('canvas');
mycanvas.width = v.videoWidth;
mycanvas.height = v.videoHeight;
mycanvas.getContext('2d').drawImage(v, 0, 0);
// 图片数据转换成数组
data = mycanvas.toDataURL('image/webp');
document.getElementById('photo').setAttribute('src', data);
// ajax提交数据到后台
$.ajax({
type:"POST",
url:'http://127.0.0.1:8000/regist/',
data:{username:$("#username").val(),mobile:$('#mobile').val(),password:$('#password').val(),mobile_code:$('#mobile_code').val(),imagecontent:data},
dataType:"json",
success:function(data){
alert(data.result)
$('#resText').text(data['result']);
if(data.code == 200){
window.location.href='http://127.0.0.1:8000/home/'
}else{
alert(data.result);
}
}
})
}
}, false);
3.将已经注册的应用中的各种id和key贴上来
# 导入百度AI
from django.apps import AppConfig
from aip import AipFace
import json
# django内置事务
from django.db import transaction
# 导入状态码
from jyapp.ErrorCode import * # 官网给出的状态码,通过pandas读出保存到 # 百度AI基本信息
class AppConfig(AppConfig):
name = ''
APP_ID = ''
API_KEY = ''
SECRECT_KEY = ''
client = AipFace(APP_ID,API_KEY,SECRECT_KEY)
client.setConnectionTimeoutInMillis(1000*5)
client.setSocketTimeoutInMillis(1000*5)
4.注册接口,按照接口文档传入必须的参数,手机验证码功能已在本文中注释掉,需要时自行百度。
# 注册
class Regist(View):
def get(self,request):
return render(request,'moban_index.html')
def post(self,request):
# 获取前端数据
imagecontent = request.POST.get('imagecontent')
username = request.POST.get('username')
mobile = request.POST.get('mobile')
password = request.POST.get('password')
# mobile_code = request.POST.get('mobile_code')
# print(imagecontent,username,mobile,password,mobile_code)
# mobile_code_right = request.session.get('message_code')
if not all([imagecontent,username,mobile,password]):
return JsonResponse({'result':'注册信息不能为空'})
# if mobile_code != mobile_code_right:
# return JsonResponse({'result':'请输入正确的验证码'})
else:
# 验证该用户是否存在
user = models.User.objects.filter(mobile=mobile)
if user:
return JsonResponse({'result':'该用户已存在,请直接登录'})
else:
try:
# 引入事务
with transaction.atomic():
# 分割字符串
base_data = imagecontent.split(',')[1]
# base64解码
base64_decode = base64.b64decode(base_data)
# 图片写入本地
with open('static/image/'+mobile+'.jpeg', 'wb') as f:
f.write(base64_decode)
# 添加到mysql数据库
models.User.objects.create(
imagecontent = 'static/image/'+mobile+'.jpeg', # 可以根据需求是否保存注册照片到数据库,也可以通过百度AI人脸库查看
username = username,
mobile = mobile,
password = password,
)
imageType = 'BASE64'
groupId = 'usergroup' # 自定义
userId = mobile
# 加入可选参数
options = {}
options['user_info'] = username
options['quality_control'] = 'NORMAL'
options['liveness_control'] = 'LOW'
result = AppConfig.client.addUser(base_data,imageType,groupId,userId,options)
print(result)
error_code = result['error_code']
if isinstance(error_code,int) and error_code == 0:
request.session['mobile'] = mobile
return JsonResponse({'code':200,'result':'注册成功'})
# return JsonResponse({'result':'注册成功'})
else:
error = ErrorCode().getErrorInfo(error_code)
return JsonResponse({'result':'{}'.format(error)})
except:
return JsonResponse({'result':'注册失败'})
5.登录.html
<div class="tab-content-inner" data-content="login">
<!-- <form action="{% url 'login' %}" method="POST"> -->
<div class="row form-group">
<div class="col-md-12">
<input type="text" class="form-control" id="mobile1" placeholder="请输入手机号">
</div>
</div>
<div class="row form-group">
<div class="col-md-12">
<input type="password" class="form-control" id="password1" placeholder="请输入密码">
</div>
</div> <div class="row form-group">
<div class="col-md-12">
<input type="submit" class="btn btn-primary" value="密码登陆" id="login">
<input type="submit" class="btn btn-primary" value="人脸登陆" id="login_face">
</div>
</div>
<!-- </form> -->
</div>
6.ajax封装登录信息
document.getElementById('login_face').addEventListener('click', function () {
if (videoPlaying) {
mycanvas = document.getElementById('canvas');
mycanvas.width = v.videoWidth;
mycanvas.height = v.videoHeight;
mycanvas.getContext('2d').drawImage(v, 0, 0);
data = mycanvas.toDataURL('image/webp');
document.getElementById('photo').setAttribute('src', data); $.ajax({
type:"POST",
url:'http://127.0.0.1:8000/login_face/',
data:{mobile:$('#mobile1').val(),imagecontent:data},
dataType:"json",
success:function(data){
$('#resText').text(data['result']);
document.getElementById('photo').setAttribute('src','static/'+data['point72src']);
console.log(data['point72src'])
if(data.code == 200){
alert(data.result)
window.location.href='http://127.0.0.1:8000/idcard/'
}else{
alert(data.result);
}
}
})
}
}, false);
7.人脸快速登录
class Login_face(View):
def get(self,request):
return render(request,'moban_index.html')
def post(self,request):
imagecontent = request.POST.get('imagecontent')
mobile = request.POST.get('mobile')
if not all([imagecontent,mobile]):
return JsonResponse({'code':100,'result':'登录信息不能为空'})
else:
user = models.User.objects.filter(mobile=mobile)
if not user:
return JsonResponse({'code':113,'result':'用户不存在'})
else:
base_data = imagecontent.split(',')[1]
imageType = 'BASE64'
groupIdList = 'usergroup'
# 加入可选参数
options = {}
options['max_user_num'] = 1
options['quality_control'] = 'NORMAL'
options['liveness_control'] = 'LOW'
# options['user_id'] = mobile
result = AppConfig.client.search(base_data,imageType,groupIdList,options)
print(result)
error_code = result['error_code']
try:
user_id = result['result']['user_list'][0]['user_id']
score = result['result']['user_list'][0]['score']
if isinstance(error_code,int) and error_code == 0 and user_id == mobile and score >= 90:
request.session['mobile'] = mobile
return JsonResponse({'code':200,'result':'快速登录成功'})
else:
error = ErrorCode().getErrorInfo(error_code)
return JsonResponse({'result':'{}'.format(error)})
except:
error = ErrorCode().getErrorInfo(error_code)
return JsonResponse({'result':'{}'.format(error)})
结束!
django--调用百度AI接口实现人脸注册登录的更多相关文章
- WebApiClientCore简约调用百度AI接口
WebApiClientCore WebApiClient.JIT/AOT的netcore版本,集高性能高可扩展性于一体的声明式http客户端库,特别适用于微服务的restful资源请求,也适用于各种 ...
- Winform调用百度地图接口简单示例
1.首先用一个html文件调用百度地图接口(主要注册一个序列号): <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitiona ...
- c# 利用AForge和百度AI开发实时人脸识别
baiduAIFaceIdentify项目是C#语言,集成百度AI的SDK利用AForge开发的实时人脸识别的小demo,里边包含了人脸检测识别,人脸注册,人脸登录等功能 人脸实时检测识别功能 思路是 ...
- 使用百度ai接口加图灵机器人完成简单web版语音对话
app文件 from flask import Flask, request, render_template, jsonify, send_file from uuid import uuid4 i ...
- js调用百度地图接口
原文:js调用百度地图接口 这是前几天公司做的新项目,上面需要用到地图的数据.第一次做这类型的东西没啥思路,咱们经理说,这东西简单,截个图存文件夹里调整好尺寸,数据库里存上图片的地址动态调用就行了.心 ...
- selenium自动化 | 借助百度AI开放平台识别验证码登录职教云
#通过借助百度AI开放平台识别验证码登录职教云 from PIL import Image from aip import AipOcr import unittest # driver.get(zj ...
- Python实战---制作专属有声小说(调用百度语音合成接口)
这一次的目标是使用百度云的人工智能接口,实现文字转语音的实时转换,将小说文字转换成语音朗读出来. 百度云接口调用 百度的这个接口对于我们普通用户非常友好,他的很多功能都是免费的,而且我们每天可以免费调 ...
- 人工智能-调百度AI接口+图灵机器人
1.登陆百度AI的官网 1.注册:没有账号注册 2.创建应用 3.创建应用 4.查看应用的ID 5.Python代码 from aip import AipSpeech APP_ID = " ...
- [初识]使用百度AI接口,图灵机器人实现简单语音对话
一.准备 1.百度ai开放平台提供了优质的接口资源https://ai.baidu.com/ (基本免费) 2.在语音识别的接口中, 对中文来说, 讯飞的接口是很好的选择https://www.xf ...
随机推荐
- macOS Catalina Kernel panic 因为意外而重新启动
0x00 What's Happend? 我的 MacBook Air 在升级到 Catalina 之后,经常在休眠模式重启,随后在桌面上显示"因为意外而重新启动"的信息,以下是跟 ...
- redis scan命令使用
以前的项目中有用到redis的keys命令来获取某些key,知道看了这篇文章 https://mp.weixin.qq.com/s/SGOyGGfA6GOzxwD5S91hLw.安全起见,这次打算 ...
- RMAN异机恢复主要步骤和注意事项
以后改行了或老了回头看看,我曾经会这些,也是件愉快的事 [备份]--创建目录[oracle@test20 backup]$ mkdir -p /home/oracle/backup--备份脚本[ora ...
- grep的使用及正则表达式
1.常用选项: -E :开启扩展(Extend)的正则表达式. -i :忽略大小写(ignore case). -v :反过来(invert),只打印没有匹配的,而匹配的反而不打印. -n :显示行号 ...
- 如何使用终端默认情况下阻止Mac应用保存到iCloud
当您保存要在Mac上的Pages,Numbers,TextEdit或其他基于云的应用程序中处理的文档时,该保存的默认位置是iCloud.尽管这对某些人或某些文档来说可能是一件好事,但您可能会厌倦每次更 ...
- Codeforces Round #602 (Div. 2, based on Technocup 2020 Elimination Round 3
A,有多个线段,求一条最短的线段长度,能过覆盖到所又线段,例如(2,4)和(5,6) 那么我们需要4 5连起来,长度为1,例如(2,10)(3,11),用(3,10) 思路:我们想一下如果题目说的是最 ...
- PHP 管理树莓派
同学给过我一块树莓派,那会儿觉得挺新鲜的.但是每次使用都需要远程桌面或者 ssh 进行登录,比较麻烦.后来为了方便管理,在树莓派上安装部署了 LAMP 环境,然后写了一个简单的 PHP 页面,代码如下 ...
- 连接远程服务器的几种方式/Vscode + Remote
连接远程服务器的几种方式 前言 最近在尝试做网盘,使用的技术栈大概是 .net core + MVC + Mysql + Layui,主要目的是通过这个具体的项目,熟悉熟悉 .net core 开发, ...
- python Json报错json.decoder.JSONDecodeError
近期工作中遇到一个问题,执行json.loads(json_data)时,在json_data中加上tab空格后就报错,不加则不报错 一.json.loads(json_data) 报错json.de ...
- 【朝花夕拾】Android自定义View篇之(二)Canvas常用功能
前言 转在请申明,转自[https://www.cnblogs.com/andy-songwei/p/10960012.html],谢谢! 上一篇讲View的绘制流程中讲到过,最后一步是draw流程, ...