1.前端界面實(shí)現(xiàn)
①背景閃爍效果:
<!-- 背景星星閃爍效果 -->
<script>
window.onload = function () {
// 屏幕的尺寸
var screenW = document.documentElement.clientWidth;
var screenH = document.documentElement.clientHeight;
// 2. 動(dòng)態(tài)創(chuàng)建多個(gè)星星
for(var i=0; i<300; i++){
var span = document.createElement('span');
document.body.appendChild(span);
console.log(i);
//位置隨機(jī)
var x = parseInt(Math.random() * screenW);
var y = parseInt(Math.random() * screenH);
span.style.left = x + 'px';
span.style.top = y + 'px';
/*
width: 2px;
height: 2px;
border-radius: 5px;
background-color: whitesmoke;
position: absolute;
top: 0;
left: 0;
backface-visibility: hidden;
*/
//大小隨機(jī)
var scale = Math.random() * 2;
span.style.transform = 'scale('+ scale + ', ' + scale + ')';
//頻率隨機(jī)
var rate = Math.random() *1.5;
span.style.animationDelay = rate + 's';
}
}
</script>
②翻頁(yè)效果實(shí)現(xiàn)
.shu{
position: relative;
width: 300px;
height: 400px;
background-color: rgba(255, 255, 255, 0.774);
transform-style: preserve-3d;
box-shadow: 300px 0px 30px rgb(0, 0, 0.6) inset;
transition: 1s cubic-bezier(.79,.34,.47,.92);
}
.shu::after{
content: '';
position: absolute;
height: 3px;
width: 303px;
left: 0px;
bottom: -3px;
/* background-color: rgb(100, 96, 96); */
background-image: linear-gradient(to right,rgb(71, 68, 68),rgba(124, 120, 120, 0.3) );
border-bottom-left-radius: 5px;
}
.shu::before{
content: '';
position: absolute;
width: 3px;
height: 100%;
right: -3px;
top: 0px;
background-color: rgb(112, 108, 108);
background-image: linear-gradient(to top,rgb(114, 111, 111),rgba(90, 87, 87, 0.5) );;
border-top-right-radius: 3px;
}
.shu:hover{
box-shadow: 30px 0px 30px rgb(0, 0, 0.6) inset;
transform: rotate(-5deg);
}
.shu:hover .feng{
transform: rotateY(-140deg);
}
.feng{
position: absolute;
width: 100%;
height: 100%;
z-index: 2;
background: url("../../images/img_4.png");
background-size: 100% ;
transform-origin: left;
transition: 1s cubic-bezier(.79,.34,.47,.92);
border-top-left-radius: 2px;
border-bottom-left-radius: 2px;
}
.wen{
position: absolute;
top: 0;
left: 0;
width: 100%;
height: 100%;
font-family: 'fangsong';
text-align: left;
border: solid black 1px;
font-weight: bold;
transform-origin: left; /* 旋轉(zhuǎn)軸 */
transition: 1s cubic-bezier(.79,.34,.47,.92); /* 旋轉(zhuǎn)曲線(xiàn) */
border-top-left-radius: 2px;
border-bottom-left-radius: 2px;;
}
<div class="shu" id="shu">
<div class="feng" id="feng"></div>
<div class="wen" id="wen1">
<h1 class="contain" id="register" style="padding-top:30px;padding-left: 50px;">用戶(hù)注冊(cè)</h1>
<h1 class="contain" id="faceregister" style="padding-top:20px;padding-left: 50px;">人臉注冊(cè)</h1>
<h1 class="contain" id="facelogin" style="padding-top:20px;padding-left: 50px;">人臉登錄</h1>
<h1 class="contain" id="numlogin" style="padding-top:20px;padding-left: 50px;">賬號(hào)登錄</h1>
<h1 class="contain" id="mailorphonelogin" style="padding-top:20px;padding-left: 50px;">郵箱/手機(jī)號(hào)登錄</h1>
<h1 class="contain" id="resetpwd" style="padding-top:20px;padding-left: 50px;">忘記密碼</h1>
</div>
<div class="wen" id="wen2">
<!-- 用戶(hù)注冊(cè) -->
<div id="contain1">
<h1 style="padding-top:30px;padding-left: 50px;">用戶(hù)注冊(cè)</h1>
<form class="layui-form">
<div class="layui-form-item">
<input id="num1" type="text" required lay-verify="required" placeholder="賬號(hào)" size="20">
</div>
<div class="layui-form-item">
<input id="phone1" type="text" required lay-verify="required|phone" placeholder="手機(jī)號(hào)" size="20">
</div>
<div class="layui-form-item">
<input id="mailbox1" type="text" required lay-verify="required|email" placeholder="郵箱" size="20">
</div>
<div class="layui-form-item">
<i class="layui-icon" id="show1" onclick="showordisappear(this)"></i>
<input id="pwd1" type="password" required lay-verify="required" placeholder="密碼" size="20">
</div>
<div class="layui-form-item">
<div class="layui-input-block">
<button id="btnofregister" type="button" class="layui-btn layui-btn-primary layui-border-black" lay-submit >注冊(cè)</button>
</div>
</div>
</form>
</div>
<!-- 賬號(hào)登錄 -->
<div id="contain2">
<h1 style="padding-top:30px;padding-left: 50px;">賬號(hào)登錄</h1>
<form class="layui-form">
<div class="layui-form-item">
<input id="num2" type="text" required lay-verify="required" placeholder="賬號(hào)" size="20">
<p id="tipofnum"></p>
</div>
<div class="layui-form-item">
<i class="layui-icon" id="show2" onclick="showordisappear(this)"></i>
<input id="pwd2" type="password" required lay-verify="required" placeholder="密碼" size="20">
<p id="tipofpwd"></p>
</div>
<div class="layui-form-item">
<div class="layui-input-block">
<button id="btnofnumlogin" type="button" class="layui-btn layui-btn-primary layui-border-black" lay-submit >登錄</button>
</div>
</div>
</form>
</div>
<!-- 郵箱/手機(jī)號(hào)登錄 -->
<div id="contain3">
<h1 style="padding-top:30px;padding-left: 50px;">郵箱/手機(jī)號(hào)登錄</h1>
<form class="layui-form">
<div class="layui-form-item">
<input id="mailboxorphone" type="text" required lay-verify="required" placeholder="郵箱/手機(jī)號(hào)" size="20">
<p id="tipofmop"></p>
</div>
<div class="layui-form-item">
<input id="yzm1" type="text" required lay-verify="required" placeholder="驗(yàn)證碼" size="10">
<input type="button" id="getyzm1" value="獲取驗(yàn)證碼" onclick="settime(this)">
<p id="tipofyzm1"></p>
</div>
<div class="layui-form-item">
<div class="layui-input-block">
<button id="btnofmoplogin" type="button" class="layui-btn layui-btn-primary layui-border-black" lay-submit >登錄</button>
</div>
</div>
</form>
</div>
<!-- 忘記密碼 -->
<div id="contain4">
<h1 style="padding-top:30px;padding-left: 50px;">忘記密碼</h1>
<form class="layui-form">
<div class="layui-form-item">
<input id="mailboxorphone2" type="text" required lay-verify="required" placeholder="郵箱/手機(jī)號(hào)" size="20">
<p id="tipofmop2"></p>
</div>
<div class="layui-form-item">
<input id="yzm2" type="text" required lay-verify="required" placeholder="驗(yàn)證碼" size="10">
<input type="button" id="getyzm2" value="獲取驗(yàn)證碼" onclick="settime2(this)">
<p id="tipofyzm2"></p>
</div>
<div class="layui-form-item">
<i class="layui-icon" id="show3" onclick="showordisappear(this)"></i>
<input id="pwd3" type="password" required lay-verify="required" placeholder="密碼" size="20">
<p id="tipofpwd2"></p>
</div>
<div class="layui-form-item">
<div class="layui-input-block">
<button id="btnofresetpwd" type="button" class="layui-btn layui-btn-primary layui-border-black" lay-submit >確認(rèn)</button>
</div>
</div>
</form>
</div>
</div>
</div>
2.手機(jī)驗(yàn)證碼登錄
①使用Ajax傳送給后臺(tái)傳數(shù)據(jù)
if(tip.match(/^1\d{10}$/)){
var para = {
stuphone:$("#mailboxorphone").val(),
};
$.ajax({
url :"/user/sendVerifyCode",
type : "POST",
async : true,
data : para,
dataType : 'html',
success:function (data){
eval(data)
}
});
}
②使用短信平臺(tái)發(fā)送手機(jī)短信
public class SendJunkPhoneServiceImpl implements SendJunkPhoneService{
@Resource
AyUserDao ayUserDao;
private String code;
private Date sendTime;
private static final Logger logger = LogManager.getLogger(sendemailController.class);
//短信平臺(tái)相關(guān)參數(shù)
//這個(gè)不用改
private String apiUrl = "https://sms_developer.zhenzikj.com";
//榛子云系統(tǒng)上獲取
private String appId = "######";
private String appSecret = "######";
public boolean sendJunkPhone(String stuphone){
try {
JSONObject json = null;
//隨機(jī)生成驗(yàn)證碼
code = String.valueOf(new Random().nextInt(999999));
tmp = code;
//將驗(yàn)證碼通過(guò)榛子云接口發(fā)送至手機(jī)
ZhenziSmsClient client = new ZhenziSmsClient(apiUrl, appId, appSecret);
Map<String, Object> params = new HashMap<String, Object>();
//前臺(tái)輸入的手機(jī)號(hào)
params.put("number", stuphone);
//這個(gè)模板id對(duì)應(yīng)的是榛子云個(gè)人中心的模板id
params.put("templateId", 7161);
String[] templateParams = new String[2];
templateParams[0] = code;
templateParams[1] = "1";
params.put("templateParams", templateParams);
String result = client.send(params);
sendTime = new Date();
System.out.println(result);
json = JSONObject.parseObject(result);
} catch (Exception e) {
return Boolean.FALSE;
}
return Boolean.TRUE;
}
}
3.人臉識(shí)別登錄(百度人臉識(shí)別)
①注冊(cè):
public String test(String userName,String faceBase) throws IOException {
if(!StringUtils.isEmpty(userName) && !StringUtils.isEmpty(faceBase)) {
//文件上傳的地址
String upPath = ResourceUtils.getURL("classpath:").getPath()+"static\\photo";
//用于查看路徑是否正確
System.out.println(upPath);
// 圖片名稱(chēng)
String fileName = userName+System.currentTimeMillis() + ".png";
System.out.println(upPath+"\\"+fileName);
File file = new File(upPath+"\\"+fileName);
//初始化百度云的AipFace
AipFace client = new AipFace(APP_ID, API_KEY, SECRET_KEY);
//往自己demo數(shù)據(jù)庫(kù)里插入一條用戶(hù)數(shù)據(jù)
//進(jìn)行人像數(shù)據(jù)對(duì)比
Double num = FaceUtils.verifyUser(faceBase, client);
if(num>95) {
return "2";
}
User u = ayUserDao.selectUserByName(userName);
if (u != null) {
return "3";
}
/* iUserService.addUsers(user); */
ayUserDao.addUsers(userName);
//向百度云人臉庫(kù)插入一張人臉
FaceUtils.facesetAddUse(client,faceBase,userName);
}
return "1";
}
②登錄
@RequestMapping(value = "/login2")
public String login(String faceBase,HttpSession session) {
String faceData = faceBase;
//進(jìn)行人像數(shù)據(jù)對(duì)比
AipFace client = new AipFace(APP_ID, API_KEY, SECRET_KEY);
Double num = FaceUtils.verifyUser(faceData, client);
if(num>95) {
session.setAttribute("username", faceBase);
return "1";
}else {
session.removeAttribute("username");
return "2";
}
}
第一次寫(xiě)文章,我也不知道應(yīng)該寫(xiě)什么。這個(gè)項(xiàng)目所涉及到的內(nèi)容剛學(xué)沒(méi)幾天,代碼感覺(jué)很雜亂,不過(guò)和我一樣的小白應(yīng)該能看懂。
到此這篇關(guān)于SpringBoot實(shí)現(xiàn)人臉識(shí)別等多種登錄方式的文章就介紹到這了,更多相關(guān)SpringBoot 人臉識(shí)別登錄內(nèi)容請(qǐng)搜索html5模板網(wǎng)以前的文章希望大家以后多多支持html5模板網(wǎng)!
【網(wǎng)站聲明】本站部分內(nèi)容來(lái)源于互聯(lián)網(wǎng),旨在幫助大家更快的解決問(wèn)題,如果有圖片或者內(nèi)容侵犯了您的權(quán)益,請(qǐng)聯(lián)系我們刪除處理,感謝您的支持!