设置PHP程序访问限制,彻底杜绝PHP木马入侵

2017-07-10编程教程
185

PHPCMS平台的注入漏洞太多,防不胜防,为此我想了个设置PHP程序访问限制的方法。

只允许访问以下四个PHP程序:

/index.php

/admin.php

/api.php

/phpsso_server/index.php

其它一律禁止访问。 以下是apache中虚拟主机增加的重写定义:

     RewriteEngine On

     RewriteCond %{REQUEST_FILENAME} !(\.php$) [NC]

     RewriteRule ^.*$ - [NC,L]

     RewriteRule ^/index.php(.*)$ /index.php$1 [NC,L]

     RewriteRule ^/admin.php(.*)$ /admin.php$1 [NC,L]

     RewriteRule ^/api.php(.*)$ /api.php$1 [NC,L]

     RewriteRule ^/phpsso_server/index.php(.*)$ /phpsso_server/index.php$1 [NC,L]

     RewriteRule \.php$ - [NC,F]

 

我已经测试过:对静态网页没有影响,输入任何这四个PHP之外的PHP,全部返回403.

如果其它PHP程序需要运行,可以增加rewriterule定义允许其运行。

 

不允许增加的PHP程序运行还不能完全杜绝入侵,黑客还会修改现有的PHP程序。所以还要把以下文件及目录全部改成不能写入:

 

/index.php

/api.php

/admin.php

/plugin.php

/phpcms/

/api/

/phpsso_server/

 

在程序升级时再打开写入。

在这种情况下,黑客通过phpcms漏洞肯定是进不来的了。

The End

相关推荐

C#之socket编程
编程需要恒心和毅力,最主要的是要有信心,循序渐进的完成任务。 一、socket类用于网络通信 命名空间System.Net.Sockets,完整的类引用System.Net.Sockets.Socket。Socket类支持各种网络协议。 二、简单的控制台程序 using System;using System.Collections....
2023-03-07 编程教程
114

百度UEditor编辑器如何禁止过滤div等网页html标签
将设计排版好的页面html代码上传到数据库,再读取出来的时候发现所有的div都被替换成了p标签。 解决方法: 首先在ueditor.all.js文件内搜索allowDivTransToP,找到如下的代码,将true设置为false me.setOpt({ 'allowDivTransToP':false, 'disabledTableInTable'...
2022-11-23 编程教程
495

layui Table 设置title 字体加粗
在layui.css中加样式 : .layui-table th{font-weight: bold;} ,或者直接加在网页中即可。 style .layui-table th{ font-weight: bold;} /stylebodytable id="demo" lay-filter="demo" class="layui-hide"/table/body...
2022-10-17 编程教程
200

PHP错误Warning: Cannot modify header information - headers alr
今天在用php进行图片保存输出时候,图片一直显示错误,后面用调试模式下提示:Warning: Cannot modify header information - headers already sent by... 看了一些网上的方法也没解决,最后在php.ini配置output_buffering默认为4096就没有遇到这个错误了: o...
2022-05-18 编程教程
69

Parse error: syntax error, unexpected '&'解决办法
在使用PHP5.4及以上版本时,在调用函数时,使用引用符号时,会出现Parse error: syntax error, unexpected 或PHP Fatal error: Call-time pass-by-reference has been removed者,这是由于在函数调用时通过引用传递参数已被弃用,因为它影响了代码的整洁,如...
2022-05-11 编程教程
295

解析PHP中ob_start()函数的用法
ob_start()函数用于打开缓冲区,比如header()函数之前如果就有输出,包括回车/空格/换行/都会有Header had all ready send by的错误,这时可以先用ob_start()打开缓冲区PHP代码的数据块和echo()输出都会进入缓冲区而不会立刻输出.当然打开缓冲区的作用很多,只要...
2022-05-11 编程教程
106