/ 中存储网

Apach服务器网页密码设置的方法

2013-09-13 12:34:18 来源:kejihao

在Linux或UNIX下的Apache 服务器中给网页设置密码---这是一种很简单的基于用户名/口令的认证方式,当我们在浏览器中访问经此认证模式保护的URL链接时,将会出弹出一个对话框,要求用户键入用户名和口令。用户输入后,传给Apache服务器,Apache服务器验证它的正确性,如果正确,显示页面,否则出现401错误(没有权限)。这是怎么实现的呢?下面我同过几个配置实例给大家介绍一下。

实例一:需要用户名和口令的访问控制,限制 WWW服务器中/home/httpd/html/backup/目录中网站

www.linejet.com

页面的访问,只允许用户“user1”以口令“passwd1”访问页面。

基本情况:假设

www.linejet.com

站点Apache服务器中的httpd.conf文件有设置为:

DocumentRoot /home/httpd/html

AccessFileName .htaccess

AllowOverride All

实现步骤:

1.使用htpasswd建立用户文件:

$ htpasswd -c /home/httpd/secr/.htpasswd user1

此程序会询问用户“user1”的口令,你输入“passwd1”,两次生效。

2.建立.htaccess文件

用“vi /home/httpd/html/backup/.htaccess”命令建立.htaccess文件,并写入以下几行:

AuthName My Friend Only (注:这个名字是任取的)

AuthType Basic

AuthUserFile /home/httpd/secr/.htpasswd

require user super

最后设置文件.htpasswd和.htaccess的文件权限,确保Apache用户有读的权限这样就完成了网页密码设置的工作,现在你可以在浏览器中试一试效果了。

实例二:允许一组用户访问一个目录。例如现在

www.linejet.com

站点想让myfriend

组中的m1与m2两个用户分别能使用口令“m1pass”和“m2pass”访问/home/httpd/html/

backup/目录中的页面。

实现步骤:

1.使用htpasswd建立用户文件,并在提示信息分别输入m1与m2两个用户的口令“m1pass”和“m2pass”:

htpasswd -c /home/httpd/secr/.htpasswd m1

htpasswd -c /home/httpd/secr/.htpasswd m2

2.建立组文件,用“vi /home/httpd/secr/.htgroup”命令建立.htgroup文件,并写入下面一行:

myfriend:m1 m2

3.建立.htaccess文件,用“vi /home/httpd/html/backup/.htaccess”命令,并写入以下几行:

AuthName My Friend Only

AuthType Basic

AuthUserFile /home/httpd/secr/.htpasswd

AuthGroupFile /home/httpd/secr/.htgroup

require group myfriend

这样,配置工作到此结束,可以 用m1与m2两个用户的口令做一下测试了。