星联网络专注帝国CMS二次功能插件开发-精品网站模板站长代码素材

  • 最近更新
  • 模板:33
  • 记录:12641|
  • 插件:52|
  • 工具:4|
  • 代码:8|
  • 评论:0

DedeCms 万能安全防护代码

前言

本文主要讲解《DedeCms万能安全防护代码》的详细内容

为了让大家的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. }

改为下面代码
复制代码
  1. //把get、post、cookie里的<? 替换成 <?
  2. $ckvs = Array('_GET','_POST','_COOKIE');
  3. foreach($ckvs as $ckv){
  4. if(is_array($$ckv)){
  5. foreach($$ckv AS $key => $value)
  6. if(!empty($value)){
  7. ${$ckv}[$key] = str_replace('<'.'?','&'.'lt;'.'?',$value);
  8. ${$ckv}[$key] = str_replace('?'.'>','?'.'&'.'gt;',${$ckv}[$key]);
  9. }
  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. }


这样处理之后,安全上理论上可中做到一劳永逸,但缺点是使用此功能后,不能在线上传PHP文件,如果你的站点同时支持asp、aspx等,在此基础上修改一下上述代码即可

考虑到dede如果出现问题把损失减到最小,原本在高级支持区发的内容转移给大家共享

本网刊登的文章均仅代表作者个人观点,并不代表本网立场。文中的论述和观点,敬请读者注意判断。

本文地址:http://www.xlkjgs.com/notes/web/4778.html

以上内容由本站整理呈现,请务必在转载分享时注明本文地址!如对内容有疑问,请联系我们,谢谢!

星联网络

星联网络是中国最具实战的互联网创业者的知识服务商,这里有互联网行业动态,网络推广,SEO优化,SEM优化,ESC配置,行业经验分型,互联网项目,微信营销、淘宝客赚钱、新媒体营销、京东运营、跨境电商等众多互联网营销知识分享

站长运营站长必备网站运营之道才能长久发展