java實(shí)現(xiàn)滑動(dòng)驗(yàn)證解鎖
本文實(shí)例為大家分享了java實(shí)現(xiàn)滑動(dòng)驗(yàn)證解鎖的具體代碼,供大家參考,具體內(nèi)容如下

1.html:
<div class="drag">
<div class="bg"></div>
<div class="text" onselectstart="return false;">請拖動(dòng)滑塊解鎖</div>
<div class="dragBtn">>></div>
</div>
<script>
/* 滑動(dòng)驗(yàn)證碼 */
var successRand = '';
//一、定義一個(gè)獲取DOM元素的方法
var
box = document.querySelector(".drag"),//容器
bg = document.querySelector(".bg"),//背景
text = document.querySelector(".text"),//文字
btn = document.querySelector(".dragBtn"),//滑塊
success = false,//是否通過驗(yàn)證的標(biāo)志
distance = box.offsetWidth - btn.offsetWidth;//滑動(dòng)成功的寬度(距離)
//二、給滑塊注冊鼠標(biāo)按下事件
btn.onmousedown = function(e){
//1.鼠標(biāo)按下之前必須清除掉后面設(shè)置的過渡屬性
btn.style.transition = "";
bg.style.transition ="";
//說明:clientX 事件屬性會(huì)返回當(dāng)事件被觸發(fā)時(shí),鼠標(biāo)指針向?qū)τ跒g覽器頁面(或客戶區(qū))的水平坐標(biāo)。
//2.當(dāng)滑塊位于初始位置時(shí),得到鼠標(biāo)按下時(shí)的水平位置
var e = e || window.event;
var downX = e.clientX;
//三、給文檔注冊鼠標(biāo)移動(dòng)事件
document.onmousemove = function(e){
var e = e || window.event;
//1.獲取鼠標(biāo)移動(dòng)后的水平位置
var moveX = e.clientX;
//2.得到鼠標(biāo)水平位置的偏移量(鼠標(biāo)移動(dòng)時(shí)的位置 - 鼠標(biāo)按下時(shí)的位置)
var offsetX = moveX - downX;
//3.在這里判斷一下:鼠標(biāo)水平移動(dòng)的距離 與 滑動(dòng)成功的距離 之間的關(guān)系
if( offsetX > distance){
offsetX = distance;//如果滑過了終點(diǎn),就將它停留在終點(diǎn)位置
}else if( offsetX < 0){
offsetX = 0;//如果滑到了起點(diǎn)的左側(cè),就將它重置為起點(diǎn)位置
}
//4.根據(jù)鼠標(biāo)移動(dòng)的距離來動(dòng)態(tài)設(shè)置滑塊的偏移量和背景顏色的寬度
btn.style.left = offsetX + "px";
bg.style.width = offsetX + "px";
//如果鼠標(biāo)的水平移動(dòng)距離 = 滑動(dòng)成功的寬度
if( offsetX == distance){
//1.設(shè)置滑動(dòng)成功后的樣式
text.innerHTML = "驗(yàn)證通過";
text.style.color = "#fff";
btn.innerHTML = "√";
btn.style.color = "green";
bg.style.backgroundColor = "lightgreen";
//2.設(shè)置滑動(dòng)成功后的狀態(tài)
success = true;
//成功后,清除掉鼠標(biāo)按下事件和移動(dòng)事件(因?yàn)橐苿?dòng)時(shí)并不會(huì)涉及到鼠標(biāo)松開事件)
btn.onmousedown = null;
document.onmousemove = null;
//3.成功解鎖后的回調(diào)函數(shù)
setTimeout(function(){
successRand = new Date().getTime() + Math.random();
var obj = {};
obj.rand = successRand;
$.ajax({
type: "post",
url: projectName + "/loginC/setRand",
data: JSON.stringify(obj),
datatype: 'json',
contentType: "application/json",
success: function (data) {
//console.log(vm.parent.success);
//console.log(vm.isTest);
if (data.success == true) {
} else {
layer.alert(data.message);
// change_authimage();
}
},
error: function () {
layer.alert("請求失敗");
}
});
},1);
}
}
//四、給文檔注冊鼠標(biāo)松開事件
document.onmouseup = function(e){
//如果鼠標(biāo)松開時(shí),滑到了終點(diǎn),則驗(yàn)證通過
if(success){
return;
}else{
//反之,則將滑塊復(fù)位(設(shè)置了1s的屬性過渡效果)
btn.style.left = 0;
bg.style.width = 0;
btn.style.transition = "left 1s ease";
bg.style.transition = "width 1s ease";
}
//只要鼠標(biāo)松開了,說明此時(shí)不需要拖動(dòng)滑塊了,那么就清除鼠標(biāo)移動(dòng)和松開事件。
document.onmousemove = null;
document.onmouseup = null;
}
}
// 復(fù)位驗(yàn)證滑塊
function restDragBtn() {
/*btn.style.left = 0;
bg.style.width = 0;
btn.style.transition = "left 1s ease";
bg.style.transition = "width 1s ease";
text.innerHTML = "請拖動(dòng)滑塊解鎖";
btn.innerHTML = ">>>";
text.style.color = "#a9a9a9";*/
location.reload();
}
</script>
2.后端:
@RequestMapping(value="/setRand",method = RequestMethod.POST)
@ResponseBody
@ApiOperation(value = "設(shè)置驗(yàn)證碼成功")
//@ApiImplicitParam(paramType = "query",name= "username" ,value = "用戶名",dataType = "string")
/*public void userLogin(@RequestParam(value = "username" , required = false) String username,
@RequestParam(value = "password" , required = false) String password)*/
public Message setRand(@RequestBody JSONObject json,HttpServletRequest request){
Message message = new Message();
String rand = json.getString("rand");
if(StringUtils.isNotBlank(rand)){
// 將認(rèn)證碼存入redis
HttpSession httpSession = request.getSession();
redisUtil.set(httpSession.getId() + ".rand",rand);
redisUtil.expire(httpSession.getId() + ".rand",60);
message.setSuccess(true);
}else{
message.setMessage("發(fā)生異常,請刷新重試");
}
return message;
}
3.登錄驗(yàn)證時(shí):
// 驗(yàn)證驗(yàn)證碼
String randInput = json.getString("rand");
String rand = (String) redisUtil.get(httpSession.getId() + ".rand");
if(randInput==null||!randInput.equals(rand)) {
message.setMessage("驗(yàn)證碼驗(yàn)證失敗");
// 清空驗(yàn)證碼
redisUtil.set(httpSession.getId() + ".rand","");
return message;
}
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
Java基于socket服務(wù)實(shí)現(xiàn)UDP協(xié)議的方法
這篇文章主要介紹了Java基于socket服務(wù)實(shí)現(xiàn)UDP協(xié)議的方法,通過兩個(gè)簡單實(shí)例分析了java通過socket實(shí)現(xiàn)UDP發(fā)送與接收的技巧,需要的朋友可以參考下2015-05-05
深入理解Java8新特性之Stream API的終止操作步驟
Stream是Java8的一大亮點(diǎn),是對容器對象功能的增強(qiáng),它專注于對容器對象進(jìn)行各種非常便利、高效的 聚合操作(aggregate operation)或者大批量數(shù)據(jù)操作。Stream API借助于同樣新出現(xiàn)的Lambda表達(dá)式,極大的提高編程效率和程序可讀性,感興趣的朋友快來看看吧2021-11-11
SpringCloud基本Rest微服務(wù)工程搭建過程
這篇文章主要介紹了SpringCloud基本Rest微服務(wù)工程搭建,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-01-01
bug解決Failed_to_execute_goal_org.springframework
這篇文章主要為大家介紹了bug解決Failed_to_execute_goal_org.springframework,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-09-09
Java?Stream比較兩個(gè)List的差異并取出不同的對象四種方法
今天開發(fā)一個(gè)需求時(shí)要對A和B兩個(gè)List集合遍歷,并比較出集合A有,而集合B沒有的值,下面這篇文章主要給大家介紹了關(guān)于Java?Stream比較兩個(gè)List的差異并取出不同對象的四種方法,需要的朋友可以參考下2024-01-01
Java并發(fā)編程中的volatile關(guān)鍵字詳解
這篇文章主要介紹了Java并發(fā)編程中的volatile關(guān)鍵字詳解,volatile?用于保證我們某個(gè)變量的可見性,使其一直存放在主存中,不被移動(dòng)到某個(gè)線程的私有工作內(nèi)存中,需要的朋友可以參考下2023-08-08

