日本搞逼视频_黄色一级片免费在线观看_色99久久_性明星video另类hd_欧美77_综合在线视频

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

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

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

  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>

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

生活不易,碼農辛苦
如果您覺得本網站對您的學習有所幫助,可以手機掃描二維碼進行捐贈
程序員人生
------分隔線----------------------------
分享到:
------分隔線----------------------------
關閉
程序員人生
主站蜘蛛池模板: 在线视频中文 | 韩国一级片在线播放 | 亚洲成人天堂 | 高清二区| 国产91精品一区二区 | 玖玖国产精品视频 | 久久国产日韩欧美 | 热久久中文| 国产黄页在线观看 | 久久免费影院 | 99久久精品国产一区二区三区 | 国产超碰 | 欧美在线一区二区三区四区 | 91精品91久久久中77777 | 美女视频黄 | 2019亚洲日韩新视频 | 日韩一区二区在线视频 | 久久久www| 日韩精品一二三四 | 欧美成人午夜免费视在线看片 | 欧美日韩一二三区 | 亚洲自拍偷拍网站 | 日韩视频在线播放 | 看免费黄色一级片 | 欧美一区二区三区在线看 | 亚洲电影中文字幕 | 99热精品在线 | 国产一区二区h | 精品一区二区三区久久久 | 欧美性网站 | 99re6在线视频 | 寡妇一级毛片视频 | 国内精品久久久久久 | 国产视频1区 | 久久久性| 国产欧美一区二区三区在线看蜜臀 | 日韩高清免费在线 | 黄色网址入口 | 亚洲午夜精品在线 | 免费av播放 | 亚洲国产精品久久久久 |