比較常見而且也很廉價的防范手段是在所有可能涉及用戶寫操作的表單中加 " /> 精品一区二区三区AV天堂 ,caoporn免费视频在线,99国产精品久久

天天躁日日躁狠狠躁AV麻豆-天天躁人人躁人人躁狂躁-天天澡夜夜澡人人澡-天天影视香色欲综合网-国产成人女人在线视频观看-国产成人女人视频在线观看

php安全開發(fā) 添加隨機字符串驗證,防止偽造跨站請求

yahoo對付偽造跨站請求的辦法是在表單里加入一個叫.crumb的隨機串;而facebook也有類似的解決辦法,它的表單里常常會有post_form_id和fb_dtsg。

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

隨機串代碼實現(xiàn)
咱們按照這個思路,山寨一個crumb的實現(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表示用戶唯一標識,而$ttl表示這個隨機串的有效時間。
應(yīng)用示例
構(gòu)造表單
在表單中插入一個隱藏的隨機串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
對crumb進行檢查
復(fù)制代碼 代碼如下:
<?php   
if(Crumb::verifyCrumb($uid, $_POST['crumb'])) {   
    //按照正常流程處理表單   
} else {   
    //crumb校驗失敗,錯誤提示流程   


本文出自包子博客

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

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

主站蜘蛛池模板: 青青青青青青草 | 在线日本高清日本免费 | 美女激清床上戏大全 | 自慰弄湿白丝袜 | 99久久免费视频6 | 国产一级做a爰片久久毛片男 | 免费毛片在线播放 | 久久99热这里只频精品6 | 人妻中文字幕无码系列 | 超碰国产亚洲人人 | 天天狠狠色综合图片区 | 嘟嘟嘟影院免费观看视频 | 午夜精品久久久久久影视riav | 久久re热在线视频精99 | 国产亚洲精品97在线视频一 | 边做边爱免费视频播放 | 9国产露脸精品国产麻豆 | 亚洲欧美日韩一级特黄在线 | 久久久精品免费免费直播 | 六级黄色片 | 中文字幕免费在线视频 | 美目盼兮amy198281 | 好湿好滑好硬好爽好深视频 | 国产精品久久久久无码AV色戒 | 97色伦图片97色伦图影院久久 | 久久99精国产一区二区三区四区 | 亚洲欧美国产旡码专区 | 亚洲精品久久7777777 | 影音先锋影院中文无码 | 丰满的美女射精动态图 | 久久精品AV无码亚洲色欲 | 日韩精品免费在线观看 | 国产亚洲精品久久播放 | 中文国产在线观看 | 欧美残忍xxxx极端 | 五月丁香啪啪. | 精品综合久久久久久8888 | 国产欧美日韩网站 | 久久橹| 日韩成人黄色 | 中文字幕视频免费在线观看 |