mysql>grantallprivilegeson*.* toroot @localhost identified by'password'withgrantoption; mysql>flush priveleges;
(2) 删除匿名账号和空口令账号
mysql>USE mysql; mysql>deletefromuserwhereUser=; mysql>deletefromuserwherePassword=; mysql>deletefromdb whereUser=;
web服务器安全
确保运行Nginx或者Apache的用户为一般用户,如www,注意存放数据目录权限为www
防止sql注入
if( $query_string ~* ".*[;'<>].*"){
return404;
}
关闭存放数据上传等目录的PHP解析
location ~* ^/(attachments|data)/.*.(php|php5)${
deny all;
}
针对Apache:关闭图片目录/上传等目录的PHP解析
order allow,deny Deny from all
木马查杀和防范
php木马快速查找命令
grep-r --include=*.php '[^a-z]eval($_POST'/home/wwwroot/ grep-r --include=*.php 'file_put_contents(.*$_POST[.*]);'/home/wwwroot/
利用find mtime查找最近两天或者发现木马的这几天,有哪些PHP文件被修改
find-mtime -2 -typef -name *.php
防范:
1. 做好之前的安全措施,比如禁用相关PHP函数等
2. 改变目录和文件属性
find-typef -name *.php -execchomd 644 {} ;
find-typed -execchmod755 {} ;
chown-R www.www /home/wwwroot/www.waitalone.cn
3. 为防止跨站感染,需要做虚拟主机目录隔离
(1) nginx的简单实现方法
利用nginx跑多个虚拟主机,习惯的php.ini的open_basedir配置:
open_basedir = ./:tmp:/home/wwwroot/
注:/home/wwwroot/是放置所有虚拟主机的web路径
黑客可以利用任何一个站点的webshell进入到/home/wwwroot/目录下的任何地方,这样对各个虚拟主机的危害就很大
例如: /data/www/wwwroot目录下有2个虚拟主机
修改php.ini
open_basedir = ./:/tmp:/home/wwwroot/www.sinesafe.com:/home/wwwroot/back.sinesafe.com
这样用户上传webshell就无法跨目录访问了。
(2) Apache的实现方法,控制跨目录访问
在虚拟机主机配置文件中加入
php_admin_value open_basedir "/tmp:/home/wwwroot/www.sinesafe.com"
总结
以上所述是小编给大家介绍的Linux下PHP网站服务器安全配置加固防护方法,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对易采站长站网站的支持!








