多多色-多人伦交性欧美在线观看-多人伦精品一区二区三区视频-多色视频-免费黄色视屏网站-免费黄色在线

國內最全IT社區平臺 聯系我們 | 收藏本站
阿里云優惠2
您當前位置:首頁 > php開源 > DedeCMS > DedeCMS 如何修補XSS跨站腳本攻擊

DedeCMS 如何修補XSS跨站腳本攻擊

來源:程序員人生   發布時間:2014-05-25 16:20:42 閱讀次數:3101次

  XSS又叫CSS (Cross Site Script) ,跨站腳本攻擊。它指的是惡意攻擊者往Web頁面里插入惡意html代碼,當用戶瀏覽該頁之時,嵌入其中Web里面的html代碼會被執行,從而達到惡意攻擊用戶的特殊目的。XSS屬于被動式的攻擊,因為其被動且不好利用,所以許多人常忽略其危害性。而本文主要講的是利用XSS得到目標服務器的shell。技術雖然是老技術,但是其思路希望對大家有幫助。

  首先打開文件:/include/common.func.php

  在文件中加入函數:

function RemoveXSS($val) {
$val = preg_replace('/([x00-x08,x0b-x0c,x0e-x19])/', '', $val);

$search = 'abcdefghijklmnopqrstuvwxyz';
$search .= 'ABCDEFGHIJKLMNOPQRSTUVWXYZ';
$search .= '1234567890!@#$%^&*()';
$search .= '~`";:?+/={}[]-_|'';
for ($i = 0; $i < strlen($search); $i++) {
$val = preg_replace('/(&#[xX]0{0,8}'.dechex(ord($search[$i])).';?)/i', $search[$i], $val);
$val = preg_replace('/(&#0{0,8}'.ord($search[$i]).';?)/', $search[$i], $val);
}

$ra1 = array('javascript', 'vbscript', 'expression', 'applet', 'meta', 'xml', 'blink', 'link', 'style', 'script', 'embed', 'object', 'iframe', 'frame', 'frameset', 'ilayer', 'layer', 'bgsound', 'title', 'base');
$ra2 = array('onabort', 'onactivate', 'onafterprint', 'onafterupdate', 'onbeforeactivate', 'onbeforecopy', 'onbeforecut', 'onbeforedeactivate', 'onbeforeeditfocus', 'onbeforepaste', 'onbeforeprint', 'onbeforeunload', 'onbeforeupdate', 'onblur', 'onbounce', 'oncellchange', 'onchange', 'onclick', 'oncontextmenu', 'oncontrolselect', 'oncopy', 'oncut', 'ondataavailable', 'ondatasetchanged', 'ondatasetcomplete', 'ondblclick', 'ondeactivate', 'ondrag', 'ondragend', 'ondragenter', 'ondragleave', 'ondragover', 'ondragstart', 'ondrop', 'onerror', 'onerrorupdate', 'onfilterchange', 'onfinish', 'onfocus', 'onfocusin', 'onfocusout', 'onhelp', 'onkeydown', 'onkeypress', 'onkeyup', 'onlayoutcomplete', 'onload', 'onlosecapture', 'onmousedown', 'onmouseenter', 'onmouseleave', 'onmousemove', 'onmouseout', 'onmouseover', 'onmouseup', 'onmousewheel', 'onmove', 'onmoveend', 'onmovestart', 'onpaste', 'onpropertychange', 'onreadystatechange', 'onreset', 'onresize', 'onresizeend', 'onresizestart', 'onrowenter', 'onrowexit', 'onrowsdelete', 'onrowsinserted', 'onscroll', 'onselect', 'onselectionchange', 'onselectstart', 'onstart', 'onstop', 'onsubmit', 'onunload');
$ra = array_merge($ra1, $ra2);

$found = true;
while ($found == true) {
$val_before = $val;
for ($i = 0; $i < sizeof($ra); $i++) {
$pattern = '/';
for ($j = 0; $j < strlen($ra[$i]); $j++) {
if ($j > 0) {
$pattern .= '(';
$pattern .= '(&#[xX]0{0,8}([9ab]);)';
$pattern .= '|';
$pattern .= '|(&#0{0,8}([9|10|13]);)';
$pattern .= ')*';
}
$pattern .= $ra[$i][$j];
}
$pattern .= '/i';
$replacement = substr($ra[$i], 0, 2).'<x>'.substr($ra[$i], 2);
$val = preg_replace($pattern, $replacement, $val);
if ($val_before == $val) {
$found = false;
}
}
}
return $val;
}

然后在過濾顯示的標簽中修改,例如:/templets/default/search.htm,將:

<p>
搜索 <strong class="fc_03c">{dede:global name='keyword'/}</strong> 的結果
</p>

修改為:

<p>
搜索 <strong class="fc_03c">{dede:global name='keyword' function='RemoveXSS(@me)'/}</strong> 的結果
</p>

這樣就可以了,當然其他地方顯示的地方也可以通過這個函數過濾掉。

生活不易,碼農辛苦
如果您覺得本網站對您的學習有所幫助,可以手機掃描二維碼進行捐贈
程序員人生
------分隔線----------------------------
分享到:
------分隔線----------------------------
關閉
程序員人生
主站蜘蛛池模板: www.亚洲色图.com| 最近手机中文字幕高清1 | 国产成人精品一区二三区 | 久久精品视频观看 | 欧美成人综合视频 | 久久一区不卡中文字幕 | 欧美性色xxxxxbbbbb| 亚洲欧美日韩精品 | 一区二区三区在线 | 激情粉嫩精品国产尤物 | 国产精品国产三级国产普通话对白 | 欧美视频一区在线 | 最近免费2019中文字幕大全 | 大番蕉尹人一线久久 | 国产一级淫片a视频免费观看 | 色吊丝一区二区 | 69式免费视频 | 免费在线观看黄色的网站 | 亚洲第二页 | 视频二区 调教中字 知名国产 | 黑人40厘米全进去xxxx猛交 | 亚洲一区网站 | 91久久精品一区二区三区 | 欧美性视频网 | xxnx日本免费护士 | 性久久久久久久久久 | 中文字幕无线码欧美成人 | 欧美亚洲福利 | 国产综合欧美 | α片毛片免费看 | 国产一区二区福利 | 一级女人毛片 | 精品国产精品 | 免费一级毛片正在播放 | 日日夜夜精品免费视频 | 永久在线毛片免费观看 | 免费91最新地址永久入口 | 在线视频 一区二区 | 国产l精品国产亚洲区久久 国产mv在线观看 | 免费精品久久 | 亚洲精品久久久久中文字幕一区 |