路径:/usr/local/php/etc/php.ini
php用“;”作为“注释”符号,shell用“#”作为“注释”符号;
编辑php.ini
[[email protected] ~]# vim /usr/local/php/etc/php.ini
1. 查询/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
这些函数都是高风险函数,为了安全,需要禁止这些函数。
2. 错误日志相关配置
查询/display_error
display_error=off
默认是off,若改成on,会显示当前浏览器错误,同时也会造成信息泄漏,影响安全性。
3. 查询 /log_errors
log_errors =on
4. 查询 /error_log
创建绝对路径
[[email protected] ~]# mkdir /usr/local/php/logs
授予权限(生成错误日志的用户是apache,所以要用777权限,使他可写)
[[email protected] ~]# chmod 777 /usr/local/php/logs
编辑php.ini,去掉语句前面的;号
把error_log=php_error.log改成error_log=/usr/local/php/logs/php_error.log的“绝对路径”。
5. 配置日志级别
查询 /error_reporting
error_reporting =E_ALL & ~E_NOTICE (用这两种级别)
保存退出
:wq
[[email protected] ~]# apachectl -t
Syntax OK
[[email protected] ~]# apachectl restart
这就是如何去打开错误日志,而不用暴露错误信息的配置方法,有助于排查问题。
查看错误信息:
如果发现有网页浏览错误
[[email protected] ~]# ls /usr/local/php/logs/
php_error.log
[[email protected] ~]# cat /usr/local/php/logs/php_error.log
这样就可以查看错误信息了。
6. 查询/open_basedir
编辑php.ini
找到;open_basedir= 去掉;号,改成如下路径
open_basedir=/data/www:/tmp
这是个安全选项,针对单一主机、网站、域名,把访问的权限限定在指定目录下,其他目录没有访问权限,所以这个open_basedir一定要限定在网站程序所在的目录下。
[[email protected] ~]# apachectl -t
Syntax OK
[[email protected] ~]# apachectl restart
生效。
扩展延伸学习:
针对多个主机,多个网站,多个域名,要多配置几个open_basedir的限制,如果用php.ini去编辑,只能限定配置一句;要是限制多个,我们可以针对apache的“虚拟主机配置文件”去做限制,使每一个虚拟主机一个open_basedir,我们把他们分割开,每一个站点,每一个虚拟机,每一个域名公用一个open_basedir。
配置如下:
[[email protected] ~]# vim /usr/local/apache2/conf/extra/httpd-vhosts.conf
写入:
php_admin_value open_basedir "/data/www:/tmp"
:wq
现在我们就不需要php.ini里的open_basedir配置,用;注释掉
[[email protected] ~]# apachectl -t
Syntax OK
[[email protected] ~]# apachectl restart
生效,这样做的好处是能够区分不同的虚拟机。