限定某个目录禁止解析php 限制user_agent php的配制文件PHP的动态扩展模块
Posted 牛粪也香
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了限定某个目录禁止解析php 限制user_agent php的配制文件PHP的动态扩展模块相关的知识,希望对你有一定的参考价值。
1、 限定某个目录禁止解析php(有些目录用户可以上传文件或图片,可能会被恶意者上传其它文件):
编辑:/usr/local/apache2.4/conf/extra/httpd-vhosts.conf
加入:
<Directory /var/www/222/upload>
php_admin_flag engine off
</Directory>
建立目录:mkdir /var/www/222/upload -p
写php文件:echo "<?php phpinfo(); ?>" >/var/www/222/upload/index.php
检查语法:/usr/local/apache2.4/bin/apachectl -t
重启、访问、测试:
而访问upload目录下的其它文件就没有问题:
配制文件上传目录 php不解析或禁止访问的主要目的,是为了防止恶意者上传相关木马。(注意:静态文件所存放的目录是不允许放php文件的)
2、限制user_agent(可以理解为对浏览器的标识,若遇到cc攻击的时候,可以把攻击者用的浏览器给禁止掉)
<IfModule mod_rewrite.c>
RewriteEngine on
RewriteCond %{HTTP_USER_AGENT} .*curl.* [NC,OR] (NC,忽略大小写,OR 是或者与下一个条件是或的意思)
RewriteCond %{HTTP_USER_AGENT} .*baidu.com.* [NC]
RewriteRule .* - [F] (F,forbidden)
</IfModule>
检查配制文件、重启、访问测试:
查看访问日志:
这样,就可以相对的防止恶意攻击。
curl -I 只看状况信息 -A 指定agent -x (省略host,直接指定目标ip:port)
找到路径,然后对其进行配制:
设置时区:date.timezone
把它改成:date.timezone =Asia/Shanghai 或:date.timezone =Asia/Chongqing
然后,再设置一些禁止访问的函数:
disable_functions=
把它改成:disable_functions=eval,assert,popen,passthru,escapeshellarg,escapeshellcmd,passthru,exec,system,chroot,scandir,chgrp,chown,escapeshellcmd,escapeshellarg,shell_exec,proc_get_status,ini_alter,ini_restore,dl,pfsockopen,openlog,syslog,readlink,symlink,leak,popepassthru,stream_socket_server,popen,proc_open,proc_close
访问:
为了不显示这个,就配制:display_errors
把它改成:display_errors = Off
重启apache:/usr/local/apache2.4/bin/apachectl graceful
然后再次访问:
设置php.ini文件里的错误日志,由于上面,看不到任何问题(找不到原因),所以,就得查看日志
把错误日志开启:log_errors = On
设置错误日志的存放路径:error_log = /tmp/ php_errors.log
设置错误日志的级别:error_reporting = E_ALL & ~E_DEPRECATED
然后,重启,访问
查看日志:
这里需要注意的,就是日志存放的 目录必需要有访问权限(相关用户)。
设置网站独立的目录或文件活动的权限 open_base = dir_name: (比如网站被入侵了,可能还会被人家继续渗透,这样子,就只能在这个目录范围内)
但是这样子,就会把所有的dir_name 目录给限定了,所以,意义不大。
于是就只有改虚拟机的配制文件:/usr/local/apache2.4/conf/extra/httpd-vhost.conf
在里面加入:
php_admin_value open_basedir "/var/www/222/:/tmp/" (防止,被入侵后继续扩展)
检查配制,重启,访问:
然后,改正确:
到此目录可控权限给设置完成。
4、PHP的动态扩展模块:
例如添加一个phpredis模块:
下载phpredis:wget -c https://codeload.github.com/phpredis/phpredis/zip/develop
改名:mv develop phpredis-develop.zip
解压:unzip phpredis-develop.zip
进入:cd phpredis-develop/
运行:/usr/local/php56/bin/phpize (在目录内支行/usr/local/php56/bin/phpize,目的是为了什么configure文件)
配制:./configure --with-php-config=/usr/local/php56/bin/php-config
编译安装:make && make install
编辑: vim /usr/local/php56/etc/php.ini
加入:extension=redis.so
查看:/usr/local/php56/bin/php -m |grep redis
到些phpredis 就加载成功。
其它安装模块,若源码包安装自带得有的话,就在ext下执行相关的安装操作。
例如:
步骤:
进入php的源码包:cd /home/nfyx/source/php-5.6.36/ext/
进入需要安装扩展模块的目录:cd ****/
运行这条命令:/usr/local/php56/bin/phpize (生成configure文件)
配制:./configure --with-php-config=/usr/local/php56/bin/php-config ;echo $?
编译安装:make && make install
查看默认路径下是否生成了扩展模块:ls /usr/local/php56/lib/php/extensions/no-debug-zts-20131226/
修改php.ini文件:vim /usr/local/php56/etc/php.ini
加入这行:extension=zip.so
最后进行查看是否加载:/usr/local/php56/bin/php -m |grep zip
到此源码包里面的扩展模块安装结束。
以上是关于限定某个目录禁止解析php 限制user_agent php的配制文件PHP的动态扩展模块的主要内容,如果未能解决你的问题,请参考以下文章
11.28 限定某个目录禁止解析php 11.29 限制user_agent 11.30/11.31
四十限定某个目录禁止解析php限制user_agentPHP相关配置
限定某个目录禁止解析php 限制user_agent php相关配置