POST TIME:2017-11-08 21:56
为了让大家的CMS更安全,有需要的手工在config_base.php里加上
打开
config_base.php
找到
1 | //禁止用户提交某些特殊变量 |
2 | $ckvs = Array('_GET','_POST','_COOKIE','_FILES'); |
3 | foreach($ckvs as $ckv){ |
4 | if(is_array($$ckv)){ |
5 | foreach($$ckv AS $key => $value) |
6 | if(eregi("^(cfg_|globals)",$key)) unset(${$ckv}[$key]); |
7 | } |
8 | } |
改为下面代码
01 | //把get、post、cookie里的<? 替换成 <? |
02 | $ckvs = Array('_GET','_POST','_COOKIE'); |
03 | foreach($ckvs as $ckv){ |
04 | if(is_array($$ckv)){ |
05 | foreach($$ckv AS $key => $value) |
06 | if(!empty($value)){ |
07 | ${$ckv}[$key] = str_replace('<'.'?','&'.'lt;'.'?',$value); |
08 | ${$ckv}[$key] = str_replace('?'.'>','?'.'&'.'gt;',${$ckv}[$key]); |
09 | } |
10 | if(eregi("^cfg_|globals",$key)) unset(${$ckv}[$key]); |
11 | } |
12 | } |
13 | //检测上传的文件中是否有PHP代码,有直接退出处理 |
14 | if (is_array($_FILES)) { |
15 | foreach($_FILES AS $name => $value){ |
16 | ${$name} = $value['tmp_name']; |
17 | $fp = @fopen(${$name},'r'); |
18 | $fstr = @fread($fp,filesize(${$name})); |
19 | @fclose($fp); |
20 | if($fstr!='' && ereg("<\?",$fstr)){ |
21 | echo "你上传的文件中含有危险内容,程序终止处理!"; |
22 | exit(); |
23 | } |
24 | } |
25 | } |