比較常見而且也很廉價(jià)的防范手段是在所有可能涉及用戶寫操作的表單中加 " /> 天堂成人av,不卡一区,久久99精品久久久久久

中文字幕日韩一区二区_国产一区二区av_国产毛片av_久久久久国产一区_色婷婷电影_国产一区二区精品

php安全開發(fā) 添加隨機(jī)字符串驗(yàn)證,防止偽造跨站請(qǐng)求

yahoo對(duì)付偽造跨站請(qǐng)求的辦法是在表單里加入一個(gè)叫.crumb的隨機(jī)串;而facebook也有類似的解決辦法,它的表單里常常會(huì)有post_form_id和fb_dtsg。

比較常見而且也很廉價(jià)的防范手段是在所有可能涉及用戶寫操作的表單中加入一個(gè)隨機(jī)且變換頻繁的字符串,然后在處理表單的時(shí)候?qū)@個(gè)字符串進(jìn)行檢查。這個(gè)隨機(jī)字符串如果和當(dāng)前用戶身份相關(guān)聯(lián)的話,那么攻擊者偽造請(qǐng)求會(huì)比較麻煩。現(xiàn)在防范方法基本上都是基于這種方法的了

隨機(jī)串代碼實(shí)現(xiàn)
咱們按照這個(gè)思路,山寨一個(gè)crumb的實(shí)現(xiàn),代碼如下:
復(fù)制代碼 代碼如下:
<?php   
class Crumb { 
    CONST SALT = "your-secret-salt";                                                            
    static $ttl = 7200;                                                                                           
    static public function challenge($data) {   
        return hash_hmac('md5', $data, self::SALT);   
    }                                                                                                                
    static public function issueCrumb($uid, $action = -1) {   
        $i = ceil(time() / self::$ttl);   
        return substr(self::challenge($i . $action . $uid), -12, 10);   
    }                                                                                                                
    static public function verifyCrumb($uid, $crumb, $action = -1) {   
        $i = ceil(time() / self::$ttl);                                                                              
        if(substr(self::challenge($i . $action . $uid), -12, 10) == $crumb ||   
            substr(self::challenge(($i - 1) . $action . $uid), -12, 10) == $crumb)   
            return true;                                                                                       
        return false;   
    }                                                                                                              

代碼中的$uid表示用戶唯一標(biāo)識(shí),而$ttl表示這個(gè)隨機(jī)串的有效時(shí)間。
應(yīng)用示例
構(gòu)造表單
在表單中插入一個(gè)隱藏的隨機(jī)串crumb
復(fù)制代碼 代碼如下:
<form method="post" action="demo.php">   
 <input type="hidden" name="crumb" value="<?php echo Crumb::issueCrumb($uid)?>">   
 <input type="text" name="content">   
 <input type="submit">   
 </form> 

處理表單 demo.php
對(duì)crumb進(jìn)行檢查
復(fù)制代碼 代碼如下:
<?php   
if(Crumb::verifyCrumb($uid, $_POST['crumb'])) {   
    //按照正常流程處理表單   
} else {   
    //crumb校驗(yàn)失敗,錯(cuò)誤提示流程   


本文出自包子博客

php技術(shù)php安全開發(fā) 添加隨機(jī)字符串驗(yàn)證,防止偽造跨站請(qǐng)求,轉(zhuǎn)載需保留來源!

鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標(biāo)記有誤,請(qǐng)第一時(shí)間聯(lián)系我們修改或刪除,多謝。

主站蜘蛛池模板: 亚洲一区二区三区在线视频 | 久久久久国产精品一区二区 | 国产精品免费一区二区三区四区 | 精品在线播放 | 拍真实国产伦偷精品 | 日韩淫片免费看 | 日韩一区二区三区在线视频 | 亚洲一区二区日韩 | 亚洲视频一区在线 | 特黄特黄a级毛片免费专区 av网站免费在线观看 | 午夜丁香视频在线观看 | 欧美精品在欧美一区二区 | 国产一区二区三区四区三区四 | 成人福利在线观看 | 久久久久久久久久影视 | 一级特黄色毛片 | 国产精品一区二区日韩 | 日本一区二区三区在线观看 | 99久久久久久 | 亚洲一区综合 | 操亚洲| 亚洲精品电影在线观看 | 免费a网站 | 亚洲精品久久久一区二区三区 | 婷婷一级片 | 国产日韩一区二区三免费高清 | 日本三级电影免费观看 | 久久精品欧美一区二区三区不卡 | 国产欧美一区二区三区另类精品 | 在线观看视频一区 | 中文字幕免费在线观看 | 久久精品免费观看 | 免费高清av | 91视视频在线观看入口直接观看 | 逼逼网| 老司机精品福利视频 | 欧美一区免费 | 夜夜爽99久久国产综合精品女不卡 | 欧美6一10sex性hd | 成人在线黄色 | 午夜激情影院 |