假如php程序没有指明需要register_globals的话,最好把register_globals设置为Off,这样可以避免很多安全问题的
举个例子吧,我们有一个这样的PHP文件片段叫做test.php
// 前面的代码
if ($authorised) {
// 执行一些受保护的动作
}
// 其余的代码
}
?>
假如register_globle是打开的话,入侵者可以通过提交这样一个请求来绕过验证
http://www.test.com/test.php?authorised=1
当然,假如你非得使用register_globle的话,我们在后面同样可以使用mod-security来限制一下的
open_basedir =/var/www/
上面的设置就限制了fopen(), file()等函数可以操作的目录范围,避免了入侵者非法读取文件,一定要在/var/www后面加"/",否则/var/wwww下的文件也能被访问
禁止使用phpinfo和get_cfg_var函数,这样可以避免泄露服务信息
disable_functions = phpinfo,get_cfg_var
假如我们使用了被禁止使用的phpinfo函数的话,我们可以看到这样的错误
Warning: phpinfo() has been disabled for security reasons in /var/www/info.php on line 1
设置php程序错误日志,这样我们可以很清楚的知道程序问题所在
error_reporting = E_ALL
log_errors = On
error_log = /var/log/php_err.log
默认display_error是打开的,我们在jail没弄好之前还是打开他,或许出错信息可以给我们一点提示的,但是在完工之后记得关闭这个选项啊,因为他显示出的一些出错信息有可能会暴露你的物理路径的。
在这个过程中,最需要注重的就是不能使用root做为php程序的属主,否则php程序就可以随意访问他的属主,也就是root所有的文件了,这样就完全失去了safe_mode的意义了
禁止打开远程地址,记得最近出的php include的那个漏洞吗?就是在一个php程序中include了变量,那么入侵者就可以利用这个控制服务器在本地执行远程的一个php程序,例如phpshell,所以我们关闭这个
allow_url_fopen = Off
OK,保存退出
到此为止,针对php的安全优化基本上完毕,下面我们开始给mysql"做手脚"吧
Debian下用apt装的mysql默认已经禁止从网络连接mysql了的,我们可以从他的配置文件my.cnf里看出来,但是得注重一下,RedHat的RPM,FreeBSD的ports安装,skip-networking是注释掉了的,也就是监听3306端口了,要是mysql出了什么问题,别人就可以有机会利用了
[root@debian /]grep net /etc/mysql/my.cnf
# The skip-networkin option will no longer be set via debconf menu.
# You have to manually change it if you want networking i.e. the server
skip-networking
在这个方面Debian做的不错,但是Debian和Freebsd下系统装的mysqld是动态链接的,而RedHat的RPM安装的就是静态的,我们可以通过下面的命令来查看
[root@debian ~]file `which mysqld`
/usr/sbin/mysqld: ELF 32-bit LSB executable, Intel 80386, version 1 (SYSV), for GNU/Linux 2.2.0, dynamically linked (uses shared libs), stripped
我们可以看到"dynamically linked"字样,这样在chroot mysql的时候就比较麻烦了,因为要复制很多的共享库,不过在debian下我们有makejail:)等会我们就可以看到他的威力了
接着我们修改mysql数据库里的东西,不过不管怎么样,我们首先得给mysql设置一个密码并修改治理员用户名(默认是root),但一定得记得,无论怎么样修改密码,都会有记录的,假如通过mysqladmin修改,shell的历史记录会有的,假如登陆了mysql之后再修改,在~/.mysql_history会记录的,所以我们一定得处理这两个历史记录文件,我们把他们删了,再从/dev/null做个软连接过来就可以解决问题了
评论加载中…
![]() |