Your Ad Here
首页 | 编程语言 | 网站建设 | 游戏天堂 | 冲浪宝典 | 网络安全 | 操作系统 | 软件时空 | 硬件指南 | 病毒相关 | IT 认证
软讯网络 > 软件时空 > 软件相关 > unix&linux系列二:WebApps' config & security by irunnet.com
【标  题】:unix&linux系列二:WebApps' config & security by irunnet.com
【关键字】:unix,amp,linux,WebApps,config,amp,security,by,irunnet.com
【来  源】:http://blog.csdn.net/longrujun/archive/2005/12/01/541260.aspx

unix&linux系列二:WebApps' config & security by irunnet.com

Your Ad Here

WebApps' config & security

1. Apache的安全设置

Apache
的核心设置就是在 httpd.conf 里面,我们安装的Apache的目录是在 /usr/local/apache2/ 下,那么我们的配置文件就是在 /usr/local/apache2/conf/httpd.conf

下面我们就要进行比较多的安全设置了,基本的服务、端口、主目录等等设置就不说了,只讲与安全有关的设置。

(1)
指定运行Apache服务的用户和组

这是比较重要的,因为权限是继承的,如果运行Apache服务的用户权限太高,那么很可能使得入侵者通过WebShell等就会对系统构成严重威胁。一般我们运行Apache的是nobody用户和nobody组。在httpd.conf250-275行之间找到UserGroup选项,比如我们默认设置如下(去掉了注释信息)

<IfModule !mpm_winnt.c>
<IfModule !mpm_netware.c>
User nobody
Group #-1
</IfModule>
</IfModule>

(2) Apache
的日志文件

Apache
的日志文件是非常重要的,可以发现apache的运行状况和访问情况,对于判断入侵等有重要帮助。它的默认选项是:

#
错误日志存放目录,默认是存放在apache安装目录的logs

ErrorLog logs/error_log
#
日志记录的级别,级别有debug, info, notice, warn, error, crit等,默认是“warn”级别

LogLevel warn
#
访问日志记录的格式,每一种格式都有不同的内容,根据你的需要进行定制,以获取最多访问信息

LogFormat "%h %l %u %t \"%r\" %>s %b \"%i\" \"%i\"" combined
LogFormat "%h %l %u %t \"%r\" %>s %b" common
LogFormat "%i -> %U" referer
LogFormat "%i" agent
#
使用上面格式的那一种,默认是使用common
CustomLog logs/access_log common

文件格式预定义的格式内容:

%a
远程用户
IP
%A
本地httpd服务器的
ip
%f
传送的文件名

%h
远程主机

%m
请求方式

%l identd
给出的远程名

%p
连接的httpd端口号

%P
请求的httpd进程

%t
时间

%T
服务请求时间

你可以定制自己的日志格式,然后通过CustomLog logs/access_log common来进行调用。


注意,日志文件是由运行Apache的用户进行打开的,要注意该文件的安全,防止被黑客改写或者删除。


(3) Apache
服务信息显示控制

在配置文件中有个选项是控制是否显示apache版本信息、主机名称、端口、支持的cgi等信息的:

ServerSignature On
默认为On,那么将显示所有信息:

我故意访问一个不存在的文件:
http://www.target.com/404.html
那么就会在给的错误提示中显示如下信息:

Apache/2.0.55(Unix) PHP/4..1.15 Server at irunnet.com Port 80

所有ApachePHP的信息暴露无遗,这是很不安全的。当然同时还有OffEMail选项,Off将不显示任何信息,EMail将显示管理员的邮箱地址,建议设为Off或者EMail,这样能够避免泄漏Apache服务器的信息给黑客。


(4)
目录浏览

httpd.conf中可以设置apache能够对一些没有索引文件的网页目录进行目录浏览:

<Directory />
  Options Indexes FollowSymLinks
  AllowOverride None
</Directory>
这是不合适也不安全的,建议不需要目录浏览:

<Directory />
  Options FollowSymLinks
  AllowOverride None
</Directory>

(5)
用户主页

设置httpd.conf中的
:
UserDir public_html
能够使得每个使用系统的用户在自己的主目录下建立 public_html 目录后就能够把自己的网页放进该目录,然后通过
:
http://www.irunnet.com/~用户名/网页 就能够显示自己的网页,这是不安全的,而且对于我们服务器来讲,这没有必要,所以我们直接关闭该功能:

UserDir disabled
或者把该内容改名,改成 一个黑客比较不容易猜到的文件名,比如:

UserDir webserver_public_htmlpath
也可以只允许部分用户具有该功能:

UserDir enabled user1 user2 user3

(6) CGI
执行目录

如果你的apache要执行一些perlcgi程序,那么就要设置一下选项:

ScriptAlias /cgi-bin/ "/usr/local/apache/cgi-bin/"
但是这也给了黑客利用一些不安全的cgi程序来进行破坏,所以如果你不需要cgi的话,建议关闭该选项:

#ScriptAlias /cgi-bin/ "/usr/local/apache/cgi-bin/"

(7)
控制PHP脚本只能访问指定目录

httpd.conf添加如下内容:

php_admin_value open_basedir /usr/www
后面的路径是你需要PHP脚本能够访问的目录,如果PHP脚本想要访问其他目录将出项错误提示。


目录访问控制

这项内容最复杂,同时涉及的东西也比较多,我只能简单说一下,不清楚请参考其他文章。
比如下面的内容:

<Directory />
  Options FollowSymLinks
  AllowOverride None
</Directory>
就是允许访问每一个目录,里面设置的是允许执行的动作,一般包含的动作有:OptionsAllowOverrideOrderAllowDeny

Options
是只对指定目录及其子目录能够执行的操作,IndexesIncludesFollowSymLinksExecCGIMultiViewsNoneAll等操作。

AllowOverride
是指定目录访问的权限,当然也可以通过 AccessFileName文件指定的 .htaccess 来控制。它的操作有:NoneAllOptionsFileInfoAuthConfitLimit等。

Order
AllowDeny三个指令必须配合来控制目录访问权限。Order指定检查次序的规则,比如Order Allow Deny,表示先按Allow检查,如果不匹配再按Deny进行检查。Order Deny, Allow ,表示先按Deny规则检查,如果不满足条件,再按Allow进行检查。


控制目录访问权限的文件

默认在Unix平台下能够使用 .htaccess 来对目录权限进行规则定义,但是这是不安全的,建议关闭,默认的选项:

AccessFileName .htaccess
建议设成:

#AccessFileName .htaccess
全部目录权限定义使用httpd.conf中的定义,不使用 .htaccess


(9)
用户访问认证

这个技术非常重要,能够控制一些非法用户访问本内容。假设我们的网站: http://www.irunnet.com/adminadmin是我们的后台管理目录,我不允许一些非法用户进行访问,那么我就必须设定对该目录访问是需要验证的。

先在httpd.conf中加入要进行访问认证的目录:

<Directory "/usr/www/admin">
authtype basic
authname "Private"
authuserfile /usr/local/apache/bin/admin.dat
require user login_user
Options Indexes FollowSymlinks MultiViews
AllowOverride None
</Directory>
上面我们就设置了我们的 /usr/www/admin目录是必须进行认证才能访问的,接着我们设置访问密码:

# /usr/local/apahche/bin/htpasswd -c /usr/local/apache/bin/admin.dat login_name
New password: *****
Re-type new password: *****
Adding password for user login_name

那么下次任何用户访问http://www.irunnet.com/admin目录的时候就需要输入用户名login_name和你设置的密码。


2. PHP安全设置

PHP
本身再老版本有一些问题,比如在 php4.3.10php5.0.3以前有一些比较严重的bug,所以推荐使用新版。另外,目前闹的轰轰烈烈的SQL Injection也是在PHP上有很多利用方式,所以要保证安全,PHP代码编写是一方面,PHP的配置更是非常关键。

我们php手工编译安装的,php的默认配置文件在 /usr/local/php/conf/php.ini,我们最主要就是要配置php.ini中的内容,让我们执行php能够更安全。

整个PHP中的安全设置主要是为了防止phpshellSQL Injection的攻击,一下我们慢慢探讨。


(1) 打开php的安全模式
php
的安全模式是个非常重要的内嵌的安全机制,能够控制一些php中的函数,比如system(),同时把很多文件操作函数进行了权限控制,也不允许对某些关键文件的文件,比如/etc/passwd,但是默认的php.ini是没有打开安全模式的,我们把它打开:

safe_mode = on

(2)
用户组安全

safe_mode打开时,safe_mode_gid被关闭,那么php脚本能够对文件进行访问,而且相同组的用户也能够对文件进行访问。

建议设置为:

safe_mode_gid = off
如果不进行设置,可能我们无法对我们服务器网站目录下的文件进行操作了,比如我们需要对文件进行操作的时候。


(3)
安全模式下执行程序主目录

如果安全模式打开了,但是却是要执行某些程序的时候,可以指定要执行程序的主目录:

safe_mode_exec_dir = /usr/bin
一般情况下是不需要执行什么程序的,所以推荐不要执行系统程序目录,可以指向一个目录,然后把需要执行的程序拷贝过去,比如:

safe_mode_exec_dir = /tmp/cmd
但是,我更推荐不要执行任何程序,那么就可以指向我们网页目录:

safe_mode_exec_dir = /usr/www

(4)
安全模式下包含文件

如果要在安全模式下包含某些公共文件,那么就修改一下选项:

safe_mode_include_dir = /usr/www/include/
其实一般php脚本中包含文件都是在程序自己已经写好了,这个可以根据具体需要设置。


(5)
控制php脚本能访问的目录

使用open_basedir选项能够控制PHP脚本只能访问指定的目录,这样能够避免PHP脚本访问/etc/passwd等文件,一定程度上限制了phpshell的危害,我们一般可以设置为只能访问网站目录:

open_basedir = /usr/www

(6)
关闭危险函数

如果打开了安全模式,那么函数禁止是可以不需要的,但是我们为了安全还是考虑进去。比如,我们觉得不希望执行包括system()等在那的能够执行命令的php