网站的某些资源时,浏览器弹出一个对话框,要求输入用户名和密码来获取对资源的访问。这就是用户认证的一种技术。,安全防护,黑客文讯,广西安全网络">
定阅RSS 繁体中文 设为首页 加入收藏
站内搜索
黑客文章 黑客下载
您所在的位置: 广西安全网络 >> 黑客文讯 >> 安全防护 >> 正文
Apache服务器认证
作者:佚名 来源:不详 更新:2008-8-27 14:16:59  点击:

经常上网的读者会遇到这种情况:访问一些网站的某些资源时,浏览器弹出一个对话框,要求输入用户名和密码来获取对资源的访问。这就是用户认证的一种技术。用户认证是保护Network系统资源的第一道防线,它控制着所有登录并检查访问用户的合法性,其目标是仅让合法用户以合法的权限访问Network系统的资源。基本的用户认证技术是“用户名+密码”。 

Apache是目前流行的Web服务器,可运行在Linux、Unix、Windows等操作系统下,它可以很好地解决“用户名+密码”的认证问题。Apache用户认证所需要的用户名和密码有两种不同的存贮方式:一种是文本文件;另一种是MSQL、 Oracle、MySQL等数据库。下面以Linux的Apache为例,就这两种存贮方式,分别介绍如何实现用户认证功能,同时对Windows的 Apache用户认证作简要的说明。 

采用文本文件存储 

这种认证方式的基本思想是:Apache启动认证功能后,就可以在需要限制访问的目录下建立一个名为.htaccess的文件,指定认证的配置命令。当用户第一次访问该目录的文件时,浏览器会显示一个对话框,要求输入用户名和密码,进行用户身份的确认。若是合法用户,则显示所访问的页面内容,此后访问该目录的每个页面,浏览器自动送出用户名和密码,不用再输入了,直到关闭浏览器为止。以下是实现的具体步骤: 

以Super用户root进入Linux,假设Apache 1.3.12已经编译、安装到了/usr/local/apache目录中。缺省情况下,编译Apache时自动加入mod_auth模块,利用此模块可以实现“用户名+密码”以文本文件为存储方式的认证功能。 

1.修改Apache的配置文件/usr/local/apache/conf/httpd.conf,对认证资源所在的目录设定配置命令。下例是对/usr/local/apache/htdocs/members目录的配置: 

<Directory /usr/local/apache/htdocs /members> 

Options Indexes FollowSymLinks 

allowoverride authconfig 

order allow,deny 

allow from all 

</Directory> 

其中,allowoverride authconfig一行表示允许对/usr/local/apache/htdocs/ members目录下的文件进行用户认证。 

2.在限制访问的目录/usr/local/apache/htdocs/members下建立一个文件.htaccess,其内容如下: 

AuthName "会员区" 

AuthType basic 

AuthUserFile/usr/local/apache/members.txt 

require valid-user 

说明:文件.htaccess中常用的配置命令有以下几个: 

1) AuthName命令:指定认证区域名称。区域名称是在提示要求认证的对话框中显示给用户的(见附图)。 

2)AuthType命令:指定认证类型。在HTTP1.0中,只有一种认证类型:basic。在HTTP1.1中有几种认证类型,如:MD5。 

3) AuthUserFile命令:指定一个包含用户名和密码的文本文件,每行一对。 

4) AuthGroupFile命令:指定包含用户组清单和这些组的成员清单的文本文件。组的成员之间用空格分开,如: 

managers:user1 user2 

5) require命令:指定哪些用户或组才能被授权访问。如: 

require user user1 user2(只有用户user1和user2可以访问) 

requiresgroupsmanagers (只有组managers中成员可以访问) 

require valid-user (在AuthUserFile指定的文件中任何用户都可以访问) 

3.利用Apache附带的程序htpasswd,生成包含用户名和密码的文本文件:/usr/local/apache/members.txt,每行内容格式为“用户名:密码”。 

#cd /usr/local/apache/bin 

#htpasswd -bc ../members.txt user1 1234 

#htpasswd -b ../members.txt user2 5678 

文本文件members.txt含有两个用户:user1,口令为1234;user2,口令为5678。注意,不要将此文本文件存放在Web文档的目录树中,以免被用户下载。 

欲了解htpasswd程序的帮助,请执行htpasswd -h。 

当用户数量比较少时,这种方法对用户的认证是方便、省事的,维护工作也简单。但是在用户数量有数万人,甚至数十万人时,会在查找用户上花掉一定时间,从而降低服务器的效率。这种情形,应采用数据库方式。 

采用数据库存储 

目前,Apache、PHP4、MySQL三者是Linux下构建Web网站的最佳搭档,这三个soft都是免费soft。将三者结合起来,通过HTTP协议,利用PHP4和MySQL,实现Apache的用户认证功能。 

只有在PHP4以Apache的模块方式来运行的时候才能进行用户认证。为此,在编译Apache时需要加入PHP4模块一起编译。假设PHP4作为 Apache的模块,编译、安装Apache到/usr/local/apache目录,编译、安装MySQL到/usr/local/mysql目录。然后进行下面的步骤: 

1.在MySQL中建立一个数据库member,在其中建立一个表users,用来存放合法用户的用户名和密码。 

1)用vi命令在/tmp目录建立一个SQL脚本文件auth.sql,内容为: 

drop database if exists member; 

create database member; 

use member; 

create table users ( 

username char(20) not null, 

password char(20) not null, 

); 

insertsintosusers values("user1",password("1234")); 

insertsintosusers values("user2",password("5678")); 

2)启动MySQL客户程序mysql,执行上述SQL脚本文件auth.sql的命令,在表users中增加两个用户的记录。 

#mysql -u root -pmypwd</tmp/auth.sql 

2.编写一个PHP脚本头文件auth.inc,程序内容为: 

<?php 

function authenticate() { 

Header(’WWW-authenticate: basic realm="会员区"’); 

Header(’HTTP/1.0 401 Unauthorized’); 

echo "你必须输入正确的用户名和口令。 "; 

[1] [2] 下一页

[1] [2] 下一页


转截请注明:来自 广西安全网络 Http://www.gxfa.com
在百度搜索:Apache服务器认证相关文章
在Google搜索:Apache服务器认证相关文章
在雅虎搜索:Apache服务器认证相关文章

  • 上一篇文章:

  • 下一篇文章:
  • 数据载入中,请稍后……