Apache服务器的用户认证(1)

来源:asp之家 时间:2010-05-24 18:35:00 

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

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

一.    采用文本文件存储

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

猜你喜欢

  • 域名的概念与机制(3)

    2010-02-05 18:56:00
  • AdSense重要新功能 — 在新窗口中打开广告

    2007-12-13 12:38:00
  • 利用活动日志巧妙解决IIS服务器故障

    2007-10-06 22:53:00
  • Twitter攻击事件 俄罗斯疑是幕后黑手

    2009-12-08 13:37:00
  • 微软5月底推免费望远镜工具 与谷歌天空竞争

    2008-05-13 12:29:00
  • 如何提高IT团队的执行力?

    2008-09-01 12:31:00
  • Linux watch命令的使用

    2023-11-03 03:44:18
  • 百度贴吧里诽谤帖纷飞 吓跑多个客户生意泡汤

    2009-10-15 09:36:00
  • WEB专用服务器的安全设置技巧

    2008-10-14 14:20:00
  • Google AdSense新功能 预告:轻松 管理广告单元

    2007-10-26 15:52:00
  • VMware Workstation与Device/Credential Guard不兼容

    2022-04-29 17:53:32
  • Solaris 架设FTP虚拟系统

    2009-12-22 18:54:00
  • VMware虚拟机三种联网方法及原理(小结)

    2023-10-08 17:38:49
  • 使用ZendCore给IIS安装PHP+Zend+Mysql+phpMyAdmin

    2011-01-30 17:42:00
  • 揭密百度和谷歌收录规律

    2008-12-23 13:38:00
  • Apache伪静态Rewrite详解

    2021-06-26 21:26:08
  • Vmware安装OpenWrt15.05虚拟机教程

    2022-08-17 14:54:11
  • VMware Workstation 12 Pro安装linux教程

    2022-04-18 12:49:50
  • GoDaddy美国主机是否有自己的WEB-INF目录

    2010-04-09 13:14:00
  • 2009年 比博客访问量更加重要的几个指标

    2009-01-06 10:36:00
  • asp之家 网站运营 m.aspxhome.com