溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

使用php怎么防止頁(yè)面重復(fù)提交

發(fā)布時(shí)間:2021-03-05 16:59:53 來(lái)源:億速云 閱讀:168 作者:Leah 欄目:開(kāi)發(fā)技術(shù)

使用php怎么防止頁(yè)面重復(fù)提交?很多新手對(duì)此不是很清楚,為了幫助大家解決這個(gè)難題,下面小編將為大家詳細(xì)講解,有這方面需求的人可以來(lái)學(xué)習(xí)下,希望你能有所收獲。

php有什么用

php是一個(gè)嵌套的縮寫名稱,是英文超級(jí)文本預(yù)處理語(yǔ)言,它的語(yǔ)法混合了C、Java、Perl以及php自創(chuàng)新的語(yǔ)法,主要用來(lái)做網(wǎng)站開(kāi)發(fā),許多小型網(wǎng)站都用php開(kāi)發(fā),因?yàn)閜hp是開(kāi)源的,從而使得php經(jīng)久不衰。

1、提交按鈕置disabled

      當(dāng)用戶提交后,立即把按鈕置為不可用狀態(tài)。這種用js來(lái)實(shí)現(xiàn)。

         提交前

復(fù)制代碼 代碼如下:


        $("#submit").attr('disabled','true');
         $("#submit").val("正在提交,請(qǐng)稍等");


 

       ....................................................................................

    執(zhí)行后,把按鈕置為原來(lái)狀態(tài)

復(fù)制代碼 代碼如下:


      $('#submit ').removeAttr('disabled');
      $("#submit ").val("確定提交");



2、過(guò)期時(shí)間法

    思路:當(dāng)用戶提交按鈕后生成一個(gè)token(每次業(yè)務(wù)提交token 為唯一值)存入session,并設(shè)置過(guò)期時(shí)間。當(dāng)用戶再此提交時(shí),檢測(cè)token是否一致且是否過(guò)期,若一致且沒(méi)有過(guò)期,則認(rèn)為提交了二次。當(dāng)程序執(zhí)行出錯(cuò)的時(shí)候,則需要清除存入session的值。見(jiàn)下面程序

復(fù)制代碼 代碼如下:


function checkRepeatSubmit($uniqueid = '', $expire = 30) {

        $uniqueid = empty($uniqueid) ? Yii::app()->user->id . Yii::app()->user->name . Yii::app()->user->mihome : $uniqueid;
        $token = md5("wms_check_repeat" . $uniqueid);

        $time = time();

        if (isset($_SESSION['token']) && !empty($_SESSION['token']) && $_SESSION['token'] == $token && ($time - $_SESSION['expire_time'] < $expire)) {

            return false;
        } else {

            $_SESSION['token'] = $token;
            $_SESSION['expire_time'] = $time;
            //session寫入的時(shí)候會(huì)等待整個(gè)頁(yè)面加載完成,用此函數(shù)可以立即寫入
            session_write_close();
            return true;
        }
    }

 //刪除存入的值

   function cancelRepeatSubmit() {

        unset($_SESSION['token']);
        unset($_SESSION['expire_time']);
    }


3、token銷毀法

思路:當(dāng)頁(yè)面進(jìn)行加裝的時(shí)候生成token,存在session中,并寫在表單里。表單提交的時(shí)候隨表單提交給服務(wù)端,服務(wù)端通過(guò)session存入的token與token進(jìn)行比較,若相等,則銷毀seesion中存入的token,當(dāng)頁(yè)面遭到二次提交的時(shí)候,由于存入session中的token不存在而報(bào)錯(cuò)。下面是代碼

復(fù)制代碼 代碼如下:


 /**
     * 第二種方案
     * 1、產(chǎn)生token,并存在session中
     * 2、隨頁(yè)面生成
     * 3、提交頁(yè)面與session進(jìn)行比對(duì),成功后對(duì)session進(jìn)行銷毀
     * 4、第二次提交則不存在這個(gè)值而報(bào)錯(cuò)
     * @param type $uniqueid
     * @return type
     */
    function createToken($uniqueid) {

        $uniqueid = empty($uniqueid) ? Yii::app()->user->id . Yii::app()->user->name . Yii::app()->user->mihome : $uniqueid;
        $token = md5("wms_check2_repeat" . $uniqueid);
        $_SESSION['form_token'] = $token;

       session_write_close();


        return $token;
    }

    function checkToken($token) {

        if (!isset($_SESSION['form_token']) || empty($_SESSION['form_token']) || $_SESSION['form_token'] != $token) {
            return false;
        } else {
            unset($_SESSION['form_token']);
            return true;
        }
    }

上面總結(jié)了三種方法,個(gè)人感覺(jué)第一種跟第二種方法配合著用會(huì)達(dá)到更好的效果。第二種方法與第三種方法個(gè)人感覺(jué)第三種要有優(yōu)勢(shì)點(diǎn)。

第二種與第三種方法都是把token寫在session中,這種方法好處是節(jié)省存儲(chǔ)空間,但壞處是由于session是需要整個(gè)頁(yè)面加載完畢才能寫入,故當(dāng)整個(gè)頁(yè)面加載比較慢,且用戶點(diǎn)擊多次提交,可能由于session還沒(méi)寫入導(dǎo)致系統(tǒng)還認(rèn)為是第一次輸入。導(dǎo)致驗(yàn)證不起作用。好在php函數(shù)提供了一個(gè)牛逼的函數(shù)。   session_write_close(),可以立即把session寫入,不用等待頁(yè)面加載完成。同事對(duì)于session的存入也有很多種方法可以選擇,可以存在redis,memcache或者數(shù)據(jù)庫(kù)都可以的。

看完上述內(nèi)容是否對(duì)您有幫助呢?如果還想對(duì)相關(guān)知識(shí)有進(jìn)一步的了解或閱讀更多相關(guān)文章,請(qǐng)關(guān)注億速云行業(yè)資訊頻道,感謝您對(duì)億速云的支持。

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

php
AI