国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 開發(fā) > PHP > 正文

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

2024-05-04 23:08:30
字體:
供稿:網(wǎng)友

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

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

隨機(jī)串代碼實(shí)現(xiàn)
咱們按照這個思路,山寨一個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)識,而$ttl表示這個隨機(jī)串的有效時間。
應(yīng)用示例
構(gòu)造表單
在表單中插入一個隱藏的隨機(jī)串crumb

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


<form method="post" action="demo.php">
<input type="hidden" value="<?php echo Crumb::issueCrumb($uid)?>">
<input type="text">
<input type="submit">
</form>


處理表單 demo.php
對crumb進(jìn)行檢查

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


<?php
if(Crumb::verifyCrumb($uid, $_POST['crumb'])) {
//按照正常流程處理表單
} else {
//crumb校驗(yàn)失敗,錯誤提示流程
}


本文出自包子博客

發(fā)表評論 共有條評論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 盐源县| 宁国市| 浏阳市| 桑日县| 锦屏县| 扶沟县| 大关县| 鸡泽县| 喀喇沁旗| 凤台县| 广饶县| 晋城| 彝良县| 南郑县| 鞍山市| 姚安县| 通江县| 盈江县| 望奎县| 长武县| 玉田县| 探索| 尉犁县| 镶黄旗| 疏附县| 仪陇县| 蕲春县| 原平市| 班玛县| 汪清县| 卓尼县| 新乡市| 商洛市| 和田市| 乌拉特后旗| 郸城县| 台北市| 平潭县| 外汇| 安宁市| 四会市|