JS如何實(shí)現(xiàn)form表單登錄驗(yàn)證并使用MD5加密詳解
前言
利用JS實(shí)現(xiàn)對form表單登錄提交的驗(yàn)證在大多數(shù)web中都會使用到。
首先,我們要使用JavaScript的一個庫:jQuery,jQuery是一個快速、簡潔的JavaScript框架,是繼Prototype之后又一個優(yōu)秀的JavaScript代碼庫(框架)。
這里有兩種導(dǎo)入方式:
1:項(xiàng)目內(nèi)部導(dǎo)入:
<script src="/web/WEB-INF/lib/jQuery/jQuery 3.6.4.js"></script>
這種方式需要你提前把jQuery下載到項(xiàng)目里,通過項(xiàng)目里的路徑來使用??梢匀?a rel="external nofollow" target="_blank">jQuery官網(wǎng)下載,也可以點(diǎn)擊這里下載,后綴名里有min代表的是壓縮版,功能一樣,只是把空格,空白給刪除了。
2:項(xiàng)目外部導(dǎo)入:
<script src="https://cdn.bootcdn.net/ajax/libs/jquery/3.6.4/jquery.js"></script>
這種方式可以通過CDN來使用,這種方式盡量要保持在電腦有網(wǎng)的情況下,無網(wǎng)絡(luò)的時(shí)候會連接不了。盡量用第一種方式,JQuery庫其實(shí)也不大,占不了多少內(nèi)存。
先簡單建立一個form表單。
<div> <form action="#" method="post" id="form" > <span>用戶名:</span><input type="text" id="userName" name="userName"><p id="point_1"></p><br> <span>密碼:</span><input type="password" id="pwd" name="pwd"><p id="point_2"></p><br> 性別: <input type="radio" name="sex" id="boy" value="男" checked="checked">男 <input type="radio" name="sex" id="girl" value="女" >女<br><br> <button type="submit">提交</button> <p id="point_3"></p> </form> </div>
我們可以通過form表單的submit事件來判斷在點(diǎn)擊提交后是否要對表單進(jìn)行提交。可以在submit里設(shè)置一個判斷函數(shù),符合條件就返回true,不符合就返回false(給出提示),并且不刷新頁面(event.preventDefault() 阻止submit事件發(fā)生默認(rèn)行為)。
我們要給每個輸入框設(shè)置id和name,id可以方便我們在JS里面調(diào)用該標(biāo)簽的value,name的作用是:在表單向服務(wù)器提交時(shí),提供name名字相應(yīng)的值。性別使用同一個name名字是為了男,女互斥,只能提交其中一個值。p標(biāo)簽用來顯示提示信息。
JS代碼如下:
$("#userName").blur(function (){ if($("#userName").val()===""){ $("#userName").css({"border": "3px solid red" }); $("#point_1").text("用戶名不能為空!!"); }else{ $("#userName").css({"border":"1px solid black"}); $("#point_1").text(""); } //還可以進(jìn)行其他判斷 }); $("#pwd").blur(function (){ if($("#pwd").val()===""){ $("#pwd").css({"border": "3px solid red" }); $("#point_2").text("密碼不能為空!!"); }else{ $("#pwd").css({"border":"1px solid black"}); $("#point_2").text(""); } //還可以進(jìn)行其他判斷 }); $("#form").submit(function (event){ if(($("#userName").val()!=="")&&($("#pwd").val()!=="")){ return true; }else { $("#point_3").text("請輸入正確的信息!!").css({"color":"red"}); event.preventDefault(); return false; } });
效果如下:
如果輸入都正確,那么表單就會向服務(wù)器提交信息。
提交的數(shù)據(jù)是原本的,我們可以用MD5對它進(jìn)行加密處理。
首先加入MD5的JS文件:
<script src="https://cdn.bootcss.com/blueimp-md5/2.10.0/js/md5.min.js"></script>
修改后代碼如下:
加入了一句加密代碼,直接調(diào)用MD5對原密碼進(jìn)行加密,然后再賦值給pwd。
$("#userName").blur(function (){ if($("#userName").val()===""){ $("#userName").css({"border": "3px solid red" }); $("#point_1").text("用戶名不能為空?。?); }else{ $("#userName").css({"border":"1px solid black"}); $("#point_1").text(""); } //還可以進(jìn)行其他判斷 }); $("#pwd").blur(function (){ if($("#pwd").val()===""){ $("#pwd").css({"border": "3px solid red" }); $("#point_2").text("密碼不能為空??!"); }else{ $("#pwd").css({"border":"1px solid black"}); $("#point_2").text(""); } //還可以進(jìn)行其他判斷 }); $("#form").submit(function (event){ if(($("#userName").val()!=="")&&($("#pwd").val()!=="")){ $("#pwd").val(md5($("#pwd").val()));//加密代碼 return true; }else { $("#point_3").text("請輸入正確的信息??!").css({"color":"red"}); event.preventDefault(); return false; } });
效果如下:
還有一種改進(jìn)的方式:
我們將加密后的密碼會重新賦值給input框,這樣會有明顯的密碼變化,為了不讓用戶看到這一過程我們可以加入一個hide隱藏輸入框來接受加密密碼和代替顯現(xiàn)的密碼框傳送加密密碼。
完整代碼如下:
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Title</title> <script src="https://cdn.bootcss.com/blueimp-md5/2.10.0/js/md5.min.js"></script> <script src="https://cdn.bootcdn.net/ajax/libs/jquery/3.6.4/jquery.js"></script> <!--一般還是把js下載到項(xiàng)目里,再從項(xiàng)目里導(dǎo)入--> </head> <body> <div> <form action="#" method="post" id="form" > <span>用戶名:</span><input type="text" id="userName" name="userName"><p id="point_1"></p><br> <span>密碼:</span><input type="password" id="pwd"><p id="point_2"></p><br> <!--一個隱藏框--> <input type="hidden" id="md5password" name="pwd"> 性別:<!--name的作用是讓男,女兩個標(biāo)簽互斥,只能選擇其中一個--> <input type="radio" name="sex" id="boy" value="男" checked="checked">男 <input type="radio" name="sex" id="girl" value="女" >女<br><br> <button type="submit">提交</button> <p id="point_3"></p> </form> </div> <script> $("#userName").blur(function (){ if($("#userName").val()===""){ $("#userName").css({"border": "3px solid red" }); $("#point_1").text("用戶名不能為空??!"); }else{ $("#userName").css({"border":"1px solid black"}); $("#point_1").text(""); } //還可以進(jìn)行其他判斷 }); $("#pwd").blur(function (){ if($("#pwd").val()===""){ $("#pwd").css({"border": "3px solid red" }); $("#point_2").text("密碼不能為空?。?); }else{ $("#pwd").css({"border":"1px solid black"}); $("#point_2").text(""); } //還可以進(jìn)行其他判斷 }); $("#form").submit(function (event){ if(($("#userName").val()!=="")&&($("#pwd").val()!=="")){ $("#md5password").val(md5($("#pwd").val()));//md5加密 return true; }else { $("#point_3").text("請輸入正確的信息??!").css({"color":"red"}); event.preventDefault(); return false; } }); </script> </body> </html>
總結(jié)
到此這篇關(guān)于JS如何實(shí)現(xiàn)form表單登錄驗(yàn)證并使用MD5加密的文章就介紹到這了,更多相關(guān)JS form表單登錄驗(yàn)證內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
使用js實(shí)現(xiàn)一個可編輯的select下拉列表
這篇文章主要介紹了使用js實(shí)現(xiàn)一個可編輯的select下拉列表,個人感覺還不錯,需要的朋友可以參考下2014-02-02javascript 表格排序和表頭浮動效果(擴(kuò)展SortTable)
前段時(shí)間一個項(xiàng)目有大量頁面用到表格排序和表頭浮動的效果,在網(wǎng)上找了幾個表格排序的js代碼,最后選擇了 Stuart Langridge的SortTable,在SortTable基礎(chǔ)上做了些擴(kuò)展,加上了表頭浮動效果及一些小功能。2009-04-04Smartour 讓網(wǎng)頁導(dǎo)覽變得更簡單(推薦)
這篇文章主要介紹了Smartour 讓網(wǎng)頁導(dǎo)覽變得更簡單(推薦),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-07-07JS數(shù)組屬性去重并校驗(yàn)重復(fù)數(shù)據(jù)
這篇文章主要介紹了JS數(shù)組屬性去重并校驗(yàn)重復(fù)數(shù)據(jù),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-01-01JavaScript實(shí)現(xiàn)將Excel文件渲染在頁面上
這篇文章主要為大家詳細(xì)介紹了如何使用Html和JavaScript實(shí)現(xiàn)將Excel文件渲染在頁面上,文中的示例代碼講解詳細(xì),有需要的小伙伴可以參考下2024-12-12js動態(tài)調(diào)用css屬性的小規(guī)律及實(shí)例說明
本篇文章主要介紹了js動態(tài)調(diào)用css屬性的小規(guī)律及實(shí)例說明。需要的朋友可以過來參考下,希望對大家有所幫助2013-12-12JS實(shí)現(xiàn)動態(tài)給標(biāo)簽控件添加事件的方法示例
這篇文章主要介紹了JS實(shí)現(xiàn)動態(tài)給標(biāo)簽控件添加事件的方法,結(jié)合實(shí)例形式分析了javascript簡單實(shí)現(xiàn)動態(tài)添加事件的相關(guān)操作技巧,需要的朋友可以參考下2017-05-05VScode中配置JavaScript編譯環(huán)境的方法
這篇文章主要介紹了VSCODE中配置JavaScript編譯環(huán)境的方法,方式一 使用Node.js做為解釋器運(yùn)行JS代碼 Node.js的安裝和配置,方式二使用VSCODE插件Code Runner運(yùn)行JS代碼,本文給大家介紹的非常詳細(xì),需要的朋友可以參考下2022-08-08