比較常見而且也很廉價的防范手段是在所有可能涉及用戶寫操作的表單中加 " /> av在线免费观看网址,在线播放第一页,www免费视频com

四虎精品视频-四虎精品成人免费网站-四虎黄色网-四虎国产视频-国产免费91-国产蜜臀97一区二区三区

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

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

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

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


本文出自包子博客

php技術php安全開發 添加隨機字符串驗證,防止偽造跨站請求,轉載需保留來源!

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

主站蜘蛛池模板: 小姐诱心在线| 天地无伦| 一代宗师 豆瓣| 深流 电视剧| 护学岗值班记录表| 白鹿罗云熙| 二哈和他的白猫师尊车子图片| 何丽萍| 武汉日夜| 王牌御史| 精品视频| 下巴有个凹陷| 风云太白山电影| 《白蛇传说》| 美人鱼的电影| 芭蕉扇图片| 热带夜的引诱| 第九区电影免费观看完整版| 春江花月夜理解性默写及答案| 吴爱玲| 一个都不能少电影| 江湖之社团风暴| 淡蓝色的雨简谱| 潘雨辰主演的电视剧大全| 老江湖 电影| 非常外父| 大空头 电影| 赵芮| 浙江卫视直播在线观看高清电视台| 中国未来会黑人化吗| 张天喜| 《诱惑》电影| 我们的母亲叫中国读后感| 1769视频在线播放免费观看| 十八岁免费看的电视剧| 《重紫》电视剧| 色域在线| 韩秀云讲经济| 《东北警察故事2》大结局| 骑脖子视频| 黄造时曹查理隔世情电影|