使用apache mod_env模块保存php程序敏感信息
Apache模块 mod_env
说明:允许Apache修改或清除传送到CGI脚本和SSI页面的环境变量
模块名:env_module
源文件:mod_env.c
说明:删除一个环境变量
语法:UnsetEnv env-variable [env-variable] ...
作用域:server config, virtual host, directory, .htaccess
覆盖项:FileInfo
模块:mod_env
在传送到CGI脚本和SSI页面的环境中,删除一个或多个环境变量。
如何使用:
在php程序中,如果要连接数据库,我们会写一个以下的config文件,将数据库的连接信息保存。
启用mod_env模块
说明:允许Apache修改或清除传送到CGI脚本和SSI页面的环境变量
模块名:env_module
源文件:mod_env.c
本模块用于控制传送给CGI脚本和SSI页面的环境变量。
所传送的环境变量可以来自调用 httpd 进程的shell,或者来自配置过程中所设定(set)或撤销(unset)的变量。
SetEnv 指令
说明:设置环境变量
语法:SetEnv env-variable value
作用域:server config, virtual host, directory, .htaccess
覆盖项:FileInfo
模块:mod_env
设置一个环境变量,该变量会传送到CGI脚本和SSI页面。
SetEnv SITE_PATH /home/fdipzone/demositeUnsetEnv 指令
说明:删除一个环境变量
语法:UnsetEnv env-variable [env-variable] ...
作用域:server config, virtual host, directory, .htaccess
覆盖项:FileInfo
模块:mod_env
在传送到CGI脚本和SSI页面的环境中,删除一个或多个环境变量。
UnsetEnv SITE_PATH SITE_PATH1 SITE_PATH2关于Apache mod_env模块更多说明请 查看这里
如何使用:
在php程序中,如果要连接数据库,我们会写一个以下的config文件,将数据库的连接信息保存。
<?php return array( 'database' => array( 'host' => '192.168.1.1', 'user' => 'fdipzone', 'password' => '123456', ), ); ?>这些都是比较敏感的信息,可以使用apache mod_env来保存。
启用mod_env模块
sudo a2enmod env在 apache virtualHost 的 <Directory>中加入
SetEnv DBHOST 192.168.1.1 SetEnv DBUSER fdipzone SetEnv DBPASS 123456然后打印$_SERVER,在$_SERVER中会有DBHOST DBUSER DBPASS三个数据了。
Array ( [DBHOST] => 192.168.2.4 [DBUSER] => fdipzone [DBPASS] => 123456 [HTTP_HOST] => demo.fdipzone.com [HTTP_USER_AGENT] => Mozilla/5.0 (Ubuntu; X11; Linux x86_64; rv:8.0) Gecko/20100101 Firefox/8.0 [HTTP_ACCEPT] => text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8 [HTTP_ACCEPT_LANGUAGE] => en-us,en;q=0.5 [HTTP_ACCEPT_ENCODING] => gzip, deflate ...php db config文件改为
<?php return array( 'database' => array( 'host' => $_SERVER['DBHOST'], 'user' => $_SERVER['DBUSER'], 'password' => $_SERVER['DBPASS'], ), ); ?>如果在某些地方需要删除部分的环境变量,例如在某页面不需要用到DBHOST,DBUSER,DBPASS,则可以使用UnsetEnv来删除
<IfModule mod_env.c> UnsetEnv DBHOST DBUSER DBPASS </IfModule>tips:使用Env保存的数据只能在web读取,在php cli模式下是不能读取的,请根据具体需求使用。