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

php中防止偽造跨站請求的小招式

偽造跨站請求介紹
  偽造跨站請求比較難以防范,而且危害巨大,攻擊者可以通過這種方式惡作劇,發spam信息,刪除數據等等。這種攻擊常見的表現形式有:
  偽造鏈接,引誘用戶點擊,或是讓用戶在不知情的情況下訪問
  偽造表單,引誘用戶提交。表單可以是隱藏的,用圖片或鏈接的形式偽裝。
  比較常見而且也很廉價的防范手段是在所有可能涉及用戶寫操作的表單中加入一個隨機且變換頻繁的字符串,然后在處理表單的時候對這個字符串進行檢查。這個隨機字符串如果和當前用戶身份相關聯的話,那么攻擊者偽造請求會比較麻煩。
  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中防止偽造跨站請求的小招式,轉載需保留來源!

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

主站蜘蛛池模板: xnxx 日本免费 | 国产一区二区三区久久久久久久久 | 伊人焦久影院 | 福利精品| 久久88 | 欧美日韩激情 | 伊人婷婷 | 免费视频一区二区 | 成人福利| 中文字幕国产视频 | 99re在线 | 97精品超碰一区二区三区 | 国产高清精品一区二区三区 | 黄色一级电影免费观看 | 97久久久 | 男女激情网站免费 | 亚洲小说图片 | 欧美精品成人 | 在线观看成人小视频 | 欧美亚洲视频在线观看 | 亚洲精品久久久久中文字幕二区 | 国产精品一区久久久 | 婷婷久久综合 | www.四虎.com| 欧美日韩国产精品一区二区 | 成人午夜视频在线观看 | 亚洲毛片在线观看 | 精品无码久久久久久久动漫 | 美女在线一区二区 | 国产资源在线视频 | 少妇一级淫片免费播放 | 一区二区精品视频 | 在线激情视频 | 人妖一区| 欧美极品少妇xxxxⅹ免费视频 | 国产一区二区三区色淫影院 | 国内av在线 | 欧美一区免费 | 视频一区中文字幕 | 精品亚洲一区二区 | h视频在线免费 |