Apache服务器的用户认证
2009-03-03 13:49
295 查看
Apache服务器的用户认证
引言 经常上网的读者会遇到这种情况:访问一些网站的某些资源时,浏览器弹出一个对话框,要求输入用户名和密码来获取对资源的访问。这
就是用户认证的一种技术。用户认证是保护网络系统资源的第一道防线,它控制着所有登录并检查访问用户的合法性,其目标是仅让合法用户
以合法的权限访问网络系统的资源。基本的用户认证技术是“用户名+密码”。
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可以访问)
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网站的最佳搭档,这三个软件都是免费软件。将三者结合起来,通过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 "你必须输入正确的用户名和口令。 "; exit; } function CheckUser(, ) { if ( ==
""
== "") return 0; = "Select username,password FROM usersswheresusername=' and password=password(')"; = mysql_connect
('localhost', 'root', 'mypwd'); mysql_select_db('member',); = mysql_query(, ); =mysql_num_rows(); mysql_close(); if (>0) {
return 1; //有效登录 } else { return 0; //无效登录 } } ?>函数Authenticate()的作用是利用函数Header('WWW-authenticate: basic
realm="会员区"'),向浏览器发送一个认证请求消息,使浏览器弹出一个用户名/密码的对话框。当用户输入用户名和密码后,包含此PHP脚本
的URL将自动地被再次调用,将用户名、密码、认证类型分别存放到PHP4的三个特殊变量:、、,在PHP程序中可根据这三个变量值来判断是否
合法用户。Header()函数中,basic表示基本认证类型,realm的值表示认证区域名称。函数Header('HTTP/1.0 401 Unauthorized')使浏览器用
户在连续多次输入错误的用户名或密码时接收到HTTP 401错误。函数CheckUser()用来判断浏览器用户发送来的用户名、密码是否与MySQL数据
库的相同,若相同则返回1,否则返回0。其中mysql_connect('localhost', 'root', 'mypwd')的数据库用户名root和密码mypwd,应根据自己
的MySQL设置而改变。
3.在需要限制访问的每个PHP脚本程序开头增加下列程序段: <?php require('auth.inc'); if (CheckUser(,)==0) { authenticate(); }
else { echo "这是合法用户要访问的网页。"; //将此行改为向合法用户输出的网页 } ?>把需要向合法用户显示的网页内容放到else子句中
,取代上述程序段的一行: echo "这是合法用户要访问的网页。"; 这样,当用户访问该PHP脚本程序时,需要输入用户名和密码来确认用户的
身份。
Windows的Apache用户认证
1.采用文本文件存放用户名和密码时,其方法同前,但需要注意的是表示路径的目录名之间、目录名与文件名之间一律用斜线“/”分开,而
不是反斜线“”。
2.采用MySQL数据库存放用户名和密码时,首先按下列方法将PHP 4.0.3作为Apache的模块来运行,然后按上述“采用数据库存储用户名和密码
的用户认证”的方法完成。
1)下载Windows版的Apache 1.3.12、PHP 4.0.3、MySQL 3.2.32,将三个软件分别解压、安装到C:pache、C:PHP4、C:mysql目录。
2) C:PHP4SAPI目录有几个常用Web服务器的PHP模块文件,将其中php4apache.dll拷贝到Apache的modules子目录(C:pachemodules)。
3)修改Apache的配置文件C:pachenfhttpd.conf,增加以下几行: LoadModule php4_module modules/ php4apache.dll AddType
application/x-httpd-php .php3 AddType application/x-httpd-php-source .phps AddType application/x-httpd-php .php 第一行使PHP4
以Apache的模块方式运行,这样才能进行用户认证,后三行定义PHP脚本程序的扩展名。 4)在autoexec.bat文件的PATH命令中增加PHP4所在路
径“C:PHP4”,重新启动电脑。
From : http://www.knowno.cn/article.asp?id=13&page=42
PS:在我的板子上面执行htpasswd命令创建用户名密码时出错:Illegal Instructions.可以在PC上面设置好后再上传到板子里面。将认证目录设置为cgi-bin时没有效果,可以直接打开页面,在cgi-bin下创建文件夹作为需认证的目录。
引言 经常上网的读者会遇到这种情况:访问一些网站的某些资源时,浏览器弹出一个对话框,要求输入用户名和密码来获取对资源的访问。这
就是用户认证的一种技术。用户认证是保护网络系统资源的第一道防线,它控制着所有登录并检查访问用户的合法性,其目标是仅让合法用户
以合法的权限访问网络系统的资源。基本的用户认证技术是“用户名+密码”。
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可以访问)
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网站的最佳搭档,这三个软件都是免费软件。将三者结合起来,通过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 "你必须输入正确的用户名和口令。 "; exit; } function CheckUser(, ) { if ( ==
""
== "") return 0; = "Select username,password FROM usersswheresusername=' and password=password(')"; = mysql_connect
('localhost', 'root', 'mypwd'); mysql_select_db('member',); = mysql_query(, ); =mysql_num_rows(); mysql_close(); if (>0) {
return 1; //有效登录 } else { return 0; //无效登录 } } ?>函数Authenticate()的作用是利用函数Header('WWW-authenticate: basic
realm="会员区"'),向浏览器发送一个认证请求消息,使浏览器弹出一个用户名/密码的对话框。当用户输入用户名和密码后,包含此PHP脚本
的URL将自动地被再次调用,将用户名、密码、认证类型分别存放到PHP4的三个特殊变量:、、,在PHP程序中可根据这三个变量值来判断是否
合法用户。Header()函数中,basic表示基本认证类型,realm的值表示认证区域名称。函数Header('HTTP/1.0 401 Unauthorized')使浏览器用
户在连续多次输入错误的用户名或密码时接收到HTTP 401错误。函数CheckUser()用来判断浏览器用户发送来的用户名、密码是否与MySQL数据
库的相同,若相同则返回1,否则返回0。其中mysql_connect('localhost', 'root', 'mypwd')的数据库用户名root和密码mypwd,应根据自己
的MySQL设置而改变。
3.在需要限制访问的每个PHP脚本程序开头增加下列程序段: <?php require('auth.inc'); if (CheckUser(,)==0) { authenticate(); }
else { echo "这是合法用户要访问的网页。"; //将此行改为向合法用户输出的网页 } ?>把需要向合法用户显示的网页内容放到else子句中
,取代上述程序段的一行: echo "这是合法用户要访问的网页。"; 这样,当用户访问该PHP脚本程序时,需要输入用户名和密码来确认用户的
身份。
Windows的Apache用户认证
1.采用文本文件存放用户名和密码时,其方法同前,但需要注意的是表示路径的目录名之间、目录名与文件名之间一律用斜线“/”分开,而
不是反斜线“”。
2.采用MySQL数据库存放用户名和密码时,首先按下列方法将PHP 4.0.3作为Apache的模块来运行,然后按上述“采用数据库存储用户名和密码
的用户认证”的方法完成。
1)下载Windows版的Apache 1.3.12、PHP 4.0.3、MySQL 3.2.32,将三个软件分别解压、安装到C:pache、C:PHP4、C:mysql目录。
2) C:PHP4SAPI目录有几个常用Web服务器的PHP模块文件,将其中php4apache.dll拷贝到Apache的modules子目录(C:pachemodules)。
3)修改Apache的配置文件C:pachenfhttpd.conf,增加以下几行: LoadModule php4_module modules/ php4apache.dll AddType
application/x-httpd-php .php3 AddType application/x-httpd-php-source .phps AddType application/x-httpd-php .php 第一行使PHP4
以Apache的模块方式运行,这样才能进行用户认证,后三行定义PHP脚本程序的扩展名。 4)在autoexec.bat文件的PATH命令中增加PHP4所在路
径“C:PHP4”,重新启动电脑。
From : http://www.knowno.cn/article.asp?id=13&page=42
PS:在我的板子上面执行htpasswd命令创建用户名密码时出错:Illegal Instructions.可以在PC上面设置好后再上传到板子里面。将认证目录设置为cgi-bin时没有效果,可以直接打开页面,在cgi-bin下创建文件夹作为需认证的目录。
相关文章推荐
- 配置apache服务器的用户认证
- 基于apache整合svn服务器,基于mysql对用户认证
- Apache服务器的用户认证
- Apache服务器架设(设置用户认证)
- 配置apache服务器的用户认证
- RHEL4- WEB服务(十二)用户访问apache服务器认证
- 配置apache服务器的用户认证
- Apache服务器的用户认证
- 开启Apache服务器用户认证
- 设置Apache服务器之用户认证
- Apache服务器的用户认证 (节选)
- LAMP--Apache 用户认证
- centos7编译安装apache后添加用户认证和配置虚拟主机
- 服务器的大用户量的承载方案 Nginx Squid Apache PHP MySQL
- Apache的用户认证及域名跳转
- apache用户认证和静态缓存疑惑
- LAMP之apache用户认证
- apache http server用户认证
- SVN版本控制器的服务器安装端-----> VisualSvn Server包括Subversion、Apache和用户及权限管理
- Apache Httpd服务器之认证与授权 推荐