Win2003下配置 Apache 网站目录 权限 方法

Win2003下配置 Apache 网站目录 权限 方法 [时间:2009-09-28 11:47:22] 标签:- win2003 目录限制 win2003上传限制来源:本站整理 分享 | 常简单的 权限 设置,就是访问网 站时会弹出用户名和密码,通过身份验证后可以正常浏览,如下图。在 Apache 和Windows2003中配置起 来也非常方便,主要参考了Apche的手册1.建立密码文件 Apache 在其安装目录的bin子目录 中提供了htpasswd工具,用于建立密码文件: 复制代码 代码如下: htpasswd -b -c -m -d -s c:\password.txt username password其中-m -d -s都是加密的方式,具 体见参考手册2.启用认证 其中方式有多种,可以在 httpd.conf或.htaccess根目录中配置,不过在.htaccess中配置会影响服务器性能,因此这里采用httpd.conf中 加入 以下配置信息:复制代码 代码如下: Options None AllowOverride AuthConfig Order allow,deny Allow from all AuthType Basic AuthName “Restricted Files” AuthUserFile c:/password.txt Require valid-user 其中第2行是其中认证 第5行AuthType指明了基本认证方 式,这是一种不加密的认证第6行AuthName指明了认证区域, 在我们输入用户名和密码的时候起到提示的作用第7行AuthUserFile设置了密码文件 的位置,该文件不应该在网站服务下(除非你想让别人知道用户名和密码)第8行valid-user指明了所有在 password.txt出现过的用户名和密码都可以访问3.重启 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可以访问)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 、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, ); insert into users values(“user1”,password(“1234”));insert into users values(“user2”,password(“5678″));2)启动MySQL客户程序mysql,执行 上述SQL脚本文件auth.sql的命令, 在表users中增加两个用户的记录。#mysql -u root -pmypwd</tmp /auth.sql2.编写一个PHP脚本头文件 auth.inc,程序内容为:<?php function authenticate() { Header(WWW-authenticate: basic realm=”会员区”);Header(HTTP/1.0 401 Unauthorized); echo “你必须输入正确的用户名和 口令。n”;exit; } function CheckUser($uname, $pwd) { if ($uname == “” || $pwd == “”) return 0;$query = “SELECT username,password FROM users WHERE username=$unameand password=password($pwd)”;$db_id = mysql_connect(localhost, oot, mypwd);mysql_select_db(member,$db_id); $result = mysql_query($query, $db_id);$num=mysql_num_rows($result); mysql_close($db_id); if ($num>0) { return 1; // 有效登录 } else { return 0; // 无效登录 } } ?> 函数Authenticate()的作用是利用函 数Header(WWW-authenticate: basic realm=”会员区”),向浏览器发送一个认证请求消息,使浏览器弹出一个用户名/密码的对话框。当用户输入用户名和密码后,包含此PHP脚本的URL 将自动地被再次调用,将用户名、密码、认证类型分别存放到PHP4的三个特殊变量:$PHP_AUTH_USER、$PHP_AUTH_PW、$PHP_AUTH_TYPE,在PHP程序中可根据这三个变量值来判断是否合法用户。 Header()函数中,basic表示基本认证类型,realm的值表示认证区域名称。函数Header(HTTP/1.0 401 Unauthorized)使浏览器用户在连续多次输入错误的用户名或密码时接收到HTTP 401错误。函数CheckUser()用来判断浏览器用 户发送来的用户名、密码是否与MySQL数据库的相同,若相同则返回1,否则返回0。其中 mysql_connect(localhost, oot, mypwd)的数据库用户名root和密码mypwd,应根据自己的MySQL设置而改变。3.在需要限制访问的每个PHP脚本 程序开头增加下列程序段:<?php require(auth.inc); if (CheckUser($PHP_AUTH_USER,$PHP_AUTH_PW)==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:apache 、 C:PHP4、C:mysql目录。2)C:PHP4SAPI目录有几个常用Web服 务器的PHP模块文件,将其中php4apache.dll拷贝到Apache 的 modules子目录(C:apachemodules)。3)修改 Apache 的配置文件 C:apacheconfhttpd.conf,增加以下几行:LoadModule php4_module modules/ php4apache.dllAddType application/x-httpd-php .php3AddType application/x-httpd- php-source .phpsAddType application/x-httpd-php .php 第一行使PHP4以 Apache 的模块方 式运行,这样才能进行用户认证,后三行定义PHP脚本程序的扩展名。4)在autoexec.bat文件的PATH命令中 增加PHP4所在路径“C:PHP4”,重新启动电脑。

使用Wordmobi发布

发表评论?

0 条评论。

发表评论