欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

JS如何實(shí)現(xiàn)form表單登錄驗(yàn)證并使用MD5加密詳解

 更新時(shí)間:2023年06月10日 08:50:23   作者:Ridersong  
表單驗(yàn)證為終端用戶檢測無效的數(shù)據(jù)并標(biāo)記這些錯誤,是一種用戶體驗(yàn)的優(yōu)化,下面這篇文章主要給大家介紹了關(guān)于JS如何實(shí)現(xiàn)form表單登錄驗(yàn)證并使用MD5加密的相關(guān)資料,需要的朋友可以參考下

前言

利用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;
        }
    });

效果如下:

eed071f05ee84f2e9ead8f0e99d68ccd.png

如果輸入都正確,那么表單就會向服務(wù)器提交信息。

ac4d76d987da45a99e251b34168bf62c.png

9a518c574fa54f839648e010d3463df9.png

 提交的數(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;
        }
    });

 效果如下:

f7e343bf8272448bad8da5172316eac3.png

 還有一種改進(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下拉列表

    這篇文章主要介紹了使用js實(shí)現(xiàn)一個可編輯的select下拉列表,個人感覺還不錯,需要的朋友可以參考下
    2014-02-02
  • javascript 表格排序和表頭浮動效果(擴(kuò)展SortTable)

    javascript 表格排序和表頭浮動效果(擴(kuò)展SortTable)

    前段時(shí)間一個項(xiàng)目有大量頁面用到表格排序和表頭浮動的效果,在網(wǎng)上找了幾個表格排序的js代碼,最后選擇了 Stuart Langridge的SortTable,在SortTable基礎(chǔ)上做了些擴(kuò)展,加上了表頭浮動效果及一些小功能。
    2009-04-04
  • Smartour 讓網(wǎng)頁導(dǎo)覽變得更簡單(推薦)

    Smartour 讓網(wǎng)頁導(dǎo)覽變得更簡單(推薦)

    這篇文章主要介紹了Smartour 讓網(wǎng)頁導(dǎo)覽變得更簡單(推薦),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-07-07
  • JS數(shù)組屬性去重并校驗(yàn)重復(fù)數(shù)據(jù)

    JS數(shù)組屬性去重并校驗(yàn)重復(fù)數(shù)據(jù)

    這篇文章主要介紹了JS數(shù)組屬性去重并校驗(yàn)重復(fù)數(shù)據(jù),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-01-01
  • JavaScript實(shí)現(xiàn)將Excel文件渲染在頁面上

    JavaScript實(shí)現(xiàn)將Excel文件渲染在頁面上

    這篇文章主要為大家詳細(xì)介紹了如何使用Html和JavaScript實(shí)現(xiàn)將Excel文件渲染在頁面上,文中的示例代碼講解詳細(xì),有需要的小伙伴可以參考下
    2024-12-12
  • javascript trie前綴樹的示例

    javascript trie前綴樹的示例

    這篇文章主要介紹了javascript trie單詞查找樹的示例,詳細(xì)的介紹了trie的概念和實(shí)現(xiàn),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2018-01-01
  • js動態(tài)調(diào)用css屬性的小規(guī)律及實(shí)例說明

    js動態(tài)調(diào)用css屬性的小規(guī)律及實(shí)例說明

    本篇文章主要介紹了js動態(tài)調(diào)用css屬性的小規(guī)律及實(shí)例說明。需要的朋友可以過來參考下,希望對大家有所幫助
    2013-12-12
  • JavaScript版本迷局介紹

    JavaScript版本迷局介紹

    有人說喜歡一個人,沒必要了解她的過去,然而想讀懂一個人,卻需要了解她的過去。
    2011-01-01
  • JS實(shí)現(xiàn)動態(tài)給標(biāo)簽控件添加事件的方法示例

    JS實(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-05
  • VScode中配置JavaScript編譯環(huán)境的方法

    VScode中配置JavaScript編譯環(huán)境的方法

    這篇文章主要介紹了VSCODE中配置JavaScript編譯環(huán)境的方法,方式一 使用Node.js做為解釋器運(yùn)行JS代碼 Node.js的安裝和配置,方式二使用VSCODE插件Code Runner運(yùn)行JS代碼,本文給大家介紹的非常詳細(xì),需要的朋友可以參考下
    2022-08-08

最新評論