[每周讨论专题]--第三期--Apache安全认证

王朝厨房·作者佚名  2007-01-05
宽屏版  字体: |||超大  

[b:49e80cc1ed][size=20:49e80cc1ed]每周讨论专题[/size:49e80cc1ed][/b:49e80cc1ed]【第三期】.......................................................点这里查看其他讨论专题

[b:49e80cc1ed][color=red:49e80cc1ed][size=24:49e80cc1ed]Apache安全认证[/size:49e80cc1ed][/color:49e80cc1ed][/b:49e80cc1ed]

[quote:49e80cc1ed]

本期讨论主旨为,如何实施和部署Apache的认证、授权和访问控制!!!

[/quote:49e80cc1ed]

xiaohua 回复于:2004-01-04 19:45:08

上次的问题还没完

HonestQiao 回复于:2004-01-06 09:50:15

用户授权和访问控制

你也许在访问某些网站时会遇到过这样的情况,当你点击某个连接时,你的浏览器会弹出一个身份验证的对话框,要求输入账号及密码,如果没有,就无法继续浏览了。有人会以为这是用CGI做出来的,其实不然,这是WWW服务器的用户授权和访问控制机制在发挥作用。

你是否还记得在设置Apache服务环境的过程中,有<Directory>……..<./Directory>这个指令,可以对不同的目录提供不同的保护。但是这样的设定,需要重新启动服务器才会生效,灵活性较差,通过AccessFile指令指定访问控制文件的方式则比较灵活,在Apache服务器中设置用户的访问控制权限步骤如下:

1、首先对httpd.conf文件进行设置如下:

<Directory /home/httpd/html>

# AllowOverride FileInfo AuthConfig Limit

# Options MultiViews Indexes SymLinksIfOwnerMatch IncludesNoExec

Options Includes FollowSymLinks Indexes

AllowOverride All //*注意AllowOverride 一定要设置为All,这样后面的.htaccess文件才会起作用

<Limit GET POST OPTIONS PROPFIND>

Order allow,deny

Allow from all

</Limit>

# <Limit PUT DELETE PATCH PROPPATCH MKCOL COPY MOVE LOCK UNLOCK>

# Order deny,allow

# Deny from all

# </Limit>

</Directory>

#指定配置存取控制权限的文件名称

AccessFileName .htaccess

2、创建.htaccess文件內容

要控制某目录的访问权限必须建立一访问控制文件,文件名前面指定的“.htaccess”,其内容格式如下:

AuthUserFile 用户帐号密码文件名

AuthGroupFile 群组帐号密码文件名

AuthName 画面提示文字

AuthType 验证方式

<Limit GET>

密码验证方式

</Limit>

用户验证方式AuthType目前提供了Basic和Digest两种。

密码检验设定方法与httpd.conf中的相关设定相同。

具体例子如下:

AuthUserFile /etc/secure.user

AuthName 安全认证中心

AuthType Basic

<Limit GET>

require valid-user

</Limit>

3、建立用户密码文件

如果你是第一次创建用户密码,命令格式如下:

htpasswd -c 密码文件名 用户名称

在上面的例子中,我们将用户密码文件放到了/etc/secure.user文件中,所以这里应按照如下进行操作:

htpasswd -c /etc/secure.user sword

程序会提示你输入两次用户的口令,然后用户密码文件就已经创建sword这个用户也添加完毕了。

如果要向密码文件中添加新的用户,按照如下命令格式进行操作:

htpasswd 密码文件 用户名称

这样,重新启动httpd后,进行该WEB目录时就会有一个对话框弹出,要求输入用户名及用户口令了。

4、如何减少访问控制对Apache性能的影响

频繁的使用访问控制会对Apache的性能产生较大的影响,那么,如何才能减少这种影响呢?最简单也是最有效的方法之一就是减少.htaccess文件的数目,这样可以避免Apache对每一个请求都要按照.htaccess文件的内容进行授权检查。它不仅在当前的目录中查找.htaccess文件,它还会在当前目录的父目录中查找。

/

/usr

/usr/local

/usr/local/etc

/usr/local/etc/httpd

/usr/local/etc/httpd/htdocs

/usr/local/etc/httpd/htdocs/docs

通常在根目录下没有htaccess文件,但Apache仍然会进行例行检查以确定该文件确实不存在。这是影响很影响服务器工作效率的事情。下面的方法可以消除这个讨厌的过程:将AllowOverride选设置为None,这样Apache就会检查.htaccess文件了。将/根目录的AllowOverride选项设为None,只将需要进行访问控制的目录下的AllowOverride选项设置为all,如下面的例子中将/根目录的AllowOverride 选项关闭了,只打开了/usr/local/etc/httpd/htdocs目录下的AllowOerride选项,这样,系统就只在/usr/local/etc/httpd/htdocs中检查.htaccess文件,达到的提高服务效率的目的。

<Directory />

AllowOverride None

</Directory>

<Directory /usr/local/etc/httpd/htdocs>

AllowOverride All

</Directory>

如果除了根目录以外,还有其它存放WWW文件的目录,你也可以采取同样的方法进行设置。比如:如果你使用UserDir来允许用户访问自己的目录,AllowOverride的设置如下:

<Directory /home/*/public_html>

AllowOverride FileInfo Indexes IncludesNOEXEC

</Directory>

5、防止用户访问指定的文件

系统中有一些文件是不适宜提供给WWW用户的,如:.htaccess、htpasswd、*.pl等,可以用<Files>达到这个目的:

<Files .htaccess>

order allow,deny

deny from all

</Files>

用户访问控制三个.htaccess文件、.htpasswd和.htgroup(用于用户授权) ,为了安全起见,应该防止用户浏览其中内容,可以在httpd.conf中加入以下内容阻止用户对其进行访问:

<Files ~”/.ht”>

Order deny, allow

Deny from all

</Files>

这样这三个文件就不会被用户访问了。

6、限制某些用户访问特定文件

<Directory>可以对目录进行约束,要限制某些用户对某个特定文件的访问可以使用<Location>,比如:不允许非domain.com域内的用户对/prices/internal.html进行访问,可以用如下的设置:

<Location /prices/internal.html>

order deny,allow

deny from all

allow from .domain.com

</Location>

如果你要授于相应权限的机器没有公开的域名,请在你的/etc/hosts文件中,将其IP地址映射到某个指定的名称,然后在Location中对其进行设置,否则该选项是不起作用的。

7、只接受来自特定链接的访问

例如,只让所有来自 http://www.sina.com.cn/* 的链接的用户进入此目录,由其它链接来的访客都不得进入; " * "表示此网站底下所有的链接。其中的 http://www.sina.com.cn/* 也可以是:http://202.106.184.200/* 或是指定文件 http://www.sina.com.cn/news.html

.htaccess文件的内容如下:

AuthUserFile /dev/null

AuthGroupFile /dev/null

AuthName ExampleAllowFromSpecificURL

AuthType Basic

<Limit GET>

order deny,allow

deny from all

referer allow from http://www.sina.com.cn/*

</Limit>

饮鸩止渴 回复于:2004-01-07 10:32:32

请问如何设置,才能使用系统用户验证来访问文件呢?

wangrujun 回复于:2004-01-14 10:42:21

真不错

flute 回复于:2004-01-27 17:28:16

我有个问题:

下面是我的acce-log:

61.184.57.228 - - [27/Jan/2004:17:25:31 +0800] "-" 408 -

61.184.57.228 - - [27/Jan/2004:17:25:31 +0800] "-" 408 -

220.168.163.105 - - [27/Jan/2004:17:25:31 +0800] "-" 408 -

但err-log中什么也没有.

我把站点设成只能通过密码访问,还是出现这个问题,这是为什么??

谢谢您的回复!

zhangweibo 回复于:2004-01-27 21:46:05

提一些补充意见:

1。首先默认apache对以.ht开头的文件默认就是保护的,除非你的apache的版本太低

大家可看apache的默认配置有这么一段

#

# The following lines prevent .htaccess files from being viewed by

# Web clients. Since .htaccess files often contain authorization

# information, access is disallowed for security reasons. Comment

# these lines out if you want Web visitors to see the contents of

# .htaccess files. If you change the AccessFileName directive above,

# be sure to make the corresponding changes here.

#

# Also, folks tend to use names such as .htpasswd for password

# files, so this will protect those as well.

#

<Files ~ "^\.ht">

Order allow,deny

Deny from all

Satisfy All

</Files>

可以说apache还是想到了这个安全问题,所以大家不妨把密码文件都存为以.ht开头的文件,比武.htpasswd,责任默认都无法获取这个文件

2。另外用到用户验证可以不用All,可以只设置AuthConfig

3。不知哪位能讲讲用mysql或者其他数据库来验证apache,我觉得这个比较新鲜,呵呵

4。能不能讲讲怎么防止文件盗链,虽然网上有讲怎么设置,但我始终没成功过,不知是不是网上讲的都是错误的,还是自己错了

rocklv 回复于:2004-03-01 09:39:58

SSL中支持htaccess吗??

我试过好像不行?

露露 回复于:2004-03-03 14:59:43

求助:Apache+OpenSSL要求用户认证!

http://bbs.chinaunix.net/forum/13/20040303/272418.html

露露 回复于:2004-03-11 10:35:53

[quote="rocklv"]SSL中支持htaccess吗??

我试过好像不行?[/quote]可以的

OldRabbit2000 回复于:2004-03-11 17:15:29

请问我可以设置多了.htaccess?比如在/var/www/html/下设置一个,然后在/var/www/html/tmp再设置一个,这样会不会要求输入两次用户名密码?

setactive 回复于:2004-03-16 14:21:31

我的apache安全认证中,由于需要认证用户比较少,量也不大.

我直接把.htaccess文件中设置选项:

AuthUserFile

AuthGroupFile

AuthName

AuthType

直接放到httpd.conf配置文件中需要限制的目录(Direction)下

baobaofei 回复于:2004-03-22 15:01:31

我目前正好遇上这个问题,望老大们快多多讨论,好让我这个门外人从中受利呀。

我的网络环境是苹果。

一台苹果的服务器(XSERVER)OS :OSXS10.3.3

其它工作站有10多台苹果,另有二台PC。

苹果的OS是支持APACHE。

老大们帮我分析一下,怎么样才能做到下面的要求,谢谢。在线等。

我把公司的网页想做到这个要求,大家看一下,我应怎么做?

网页上的某个链接需要设置成身份验证,即我点击该链接就会弹出一个身份验证的对话,只要通过身份验证才能继续,否则仍返回到原页面。大家帮忙出出主意。

这个周要交老板,否则死定了。望大侠们百忙中抽点空给回个贴。

能不涉及到编程最好。如果实在要编程,那也无妨。

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
© 2005- 王朝网络 版权所有