首页 | 资讯动态 | linux基础 | 系统管理 | 网络管理 | 编程开发 | linux数据库 | linux相关 | linux认证 | 下载中心 | 专题
oklinux
 系统管理:中文环境 系统管理 桌面应用 内核技术 Linux基础:安装配置 常用命令 经验技巧 软件应用 Linux数据库:Mysql POSTGRE
 网络管理:网络安全 网络应用 Linux服务器 编程开发:PHP CC++ Python Perl SHELL 嵌入式开发 | PHP基础 PHP技巧 PHP应用 PHP文摘
 首页 linux资讯动态 Linux专题 | 其他Unix Linux解决方案 硬件相关 Linux认证 企业应用 Apache | 相关下载:资料 参考手册 开发工具
 → 当前位置:首页>linux相关>apache>正文

Linux系统Apache用户授权和访问控制

OKLinux www.oklinux.cn 2007-04-14 来源: 会员收藏 游客收藏

用户授权和访问控制

 

你也许在访问某些网站时会遇到过这样的情况,当你点击某个连接时,你的浏览器会弹出一个身份验证的对话框,要求输入账号及密码,如果没有,就无法继续浏览了。有人会以为这是用CGI做出来的,其实不然,这是WWW服务器的用户授权和访问控制机制在发挥作用。

你是否还记得在设置Apache服务环境的过程中,有……..<./Directory>这个指令,可以对不同的目录提供不同的保护。但是这样的设定,需要重新启动服务器才会生效,灵活性较差,通过AccessFile指令指定访问控制文件的方式则比较灵活,在Apache服务器中设置用户的访问控制权限步骤如下:

 

1、首先对httpd.conf文件进行设置如下:

 

 

<Directory /home/httpd/html> 
# AllowOverride FileInfo AuthConfig Limit 
# Options MultiViews Indexes SymLinksIfOwnerMatch IncludesNoExec 
Options Includes FollowSymLinks Indexes 
AllowOverride All //*注意AllowOverride 一定要设置为All,这样后面的.htaccess文件才会起作用 
<Limit GET POST OPTIONS PROPFIND> 
Order allow,deny 
Allow from all 
</Limit> 
# <Limit PUT DELETE PATCH PROPPATCH MKCOL COPY MOVE LOCK UNLOCK> 
# Order deny,allow 
# Deny from all 
# </Limit> 
</Directory> 
#指定配置存取控制权限的文件名称 
AccessFileName .htaccess

 

2、创建.htaccess文件內容

 

要控制某目录的访问权限必须建立一访问控制文件,文件名前面指定的“.htaccess”,其内容格式如下:

 

 

AuthUserFile 用户帐号密码文件名 
AuthGroupFile 群组帐号密码文件名 
AuthName 画面提示文字 
AuthType 验证方式 
<Limit GET> 
密码验证方式 
</Limit> 
用户验证方式AuthType目前提供了Basic和Digest两种。 
密码检验设定方法与httpd.conf中的相关设定相同。 
具体例子如下: 
AuthUserFile /etc/secure.user 
AuthName 安全认证中心 
AuthType Basic 
<Limit GET> 
require valid-user 
</Limit>

 

3、建立用户密码文件

 

如果你是第一次创建用户密码,命令格式如下:

htpasswd -c 密码文件名 用户名称

在上面的例子中,我们将用户密码文件放到了/etc/secure.user文件中,所以这里应按照如下进行操作:

htpasswd -c /etc/secure.user sword

程序会提示你输入两次用户的口令,然后用户密码文件就已经创建sword这个用户也添加完毕了。

如果要向密码文件中添加新的用户,按照如下命令格式进行操作:

htpasswd 密码文件 用户名称

这样,重新启动httpd后,进行该WEB目录时就会有一个对话框弹出,要求输入用户名及用户口令了。

 

4、如何减少访问控制对Apache性能的影响

频繁的使用访问控制会对Apache的性能产生较大的影响,那么,如何才能减少这种影响呢?最简单也是最有效的方法之一就是减少.htaccess文件的数目,这样可以避免Apache对每一个请求都要按照.htaccess文件的内容进行授权检查。它不仅在当前的目录中查找.htaccess文件,它还会在当前目录的父目录中查找。

 

/

/usr

/usr/local

/usr/local/etc

/usr/local/etc/httpd

/usr/local/etc/httpd/htdocs

/usr/local/etc/httpd/htdocs/docs

通常在根目录下没有htaccess文件,但Apache仍然会进行例行检查以确定该文件确实不存在。这是影响很影响服务器工作效率的事情。下面的方法可以消除这个讨厌的过程:将AllowOverride选设置为None,这样Apache就会检查.htaccess文件了。将/根目录的 AllowOverride选项设为None,只将需要进行访问控制的目录下的AllowOverride选项设置为all,如下面的例子中将/根目录的 AllowOverride 选项关闭了,只打开了/usr/local/etc/httpd/htdocs目录下的AllowOerride选项,这样,系统就只在 /usr/local/etc/httpd/htdocs中检查.htaccess文件,达到的提高服务效率的目的。

 

<Directory /> 
AllowOverride None 
</Directory> 

<Directory /usr/local/etc/httpd/htdocs> 
AllowOverride All 
</Directory>

 

 

如果除了根目录以外,还有其它存放WWW文件的目录,你也可以采取同样的方法进行设置。比如:如果你使用UserDir来允许用户访问自己的目录,AllowOverride的设置如下:

 

 

<Directory /home/*/public_html> 
AllowOverride FileInfo Indexes IncludesNOEXEC 
</Directory>

5、防止用户访问指定的文件

系统中有一些文件是不适宜提供给WWW用户的,如:.htaccess、htpasswd、*.pl等,可以用达到这个目的:

 

<Files .htaccess> 
order allow,deny 
deny from all 
</Files>

用户访问控制三个.htaccess文件、.htpasswd和.htgroup(用于用户授权) ,为了安全起见,应该防止用户浏览其中内容,可以在httpd.conf中加入以下内容阻止用户对其进行访问:

 

<Files ~”/.ht”> 
Order deny, allow 
Deny from all 
</Files>

 

这样这三个文件就不会被用户访问了。

 

6、限制某些用户访问特定文件

可以对目录进行约束,要限制某些用户对某个特定文件的访问可以使用,比如:不允许非domain.com域内的用户对/prices/internal.html进行访问,可以用如下的设置:

 

<Location /prices/internal.html> 
order deny,allow 
deny from all 
allow from .domain.com 
</Location>

如果你要授于相应权限的机器没有公开的域名,请在你的/etc/hosts文件中,将其IP地址映射到某个指定的名称,然后在Location中对其进行设置,否则该选项是不起作用的。

 

7、只接受来自特定链接的访问

例如,只让所有来自 http://www.sina.com.cn/* 的链接的用户进入此目录,由其它链接来的访客都不得进入; " * "表示此网站底下所有的链接。其中的 http://www.sina.com.cn/* 也可以是:http://202.106.184.200/* 或是指定文件 http://www.sina.com.cn/news.html

.htaccess文件的内容如下:

 

AuthUserFile /dev/null 
AuthGroupFile /dev/null 
AuthName ExampleAllowFromSpecificURL 
AuthType Basic 
<Limit GET> 
order deny,allow 
deny from all 
referer allow from http://www.sina.com.cn/* 
</Limit>
上一篇:Ubuntu新闻周报(04.09)   下一篇:演示和应急修复用的Linux Berry光盘

收藏于收藏夹】 【评论】 【推荐】 【投稿】 【打印】 【关闭

相关文章
·Linux+Apache+Mysql+PHP典型配置详解
·apache的静态/动态编译在apache+php+mysql
·Linux+Apache+Mysql+PHP典型配置方案
·静态和动态编译Apache+php+mysql全过程
·web服务器apache+mysql+php的设定
·Apache服务器配置全攻略(1)
·Apache服务器配置全攻略(2)
·Apache服务器配置全攻略(3)
·Apache服务器配置全攻略(4)
·Apache下服务器虚拟主机的设置方法介绍
发表评论
密码: 匿名评论
评论内容:(不能超过250字,需审核后才会公布,请自觉遵守互联网相关政策法规。)
站内搜索
阅读排行榜
·什么是Linux?Linux与UNIX
·使用 ActiveScaffold 增强
·提高Linux系统性能加速网
·使用源代码将 Glibc 升级
·Linux操作系统的内核引导
·Linux下推荐的常用应用程
·应用:postfix邮件服务器
·Linux用户(User)和用户
·Ubuntu Linux操作系统中的
·Linux系统下常用命令及账
最新文章
·充分利用Linux的安全防护
·如何监控和保护Linux系统
·Linux系统出现严重故障后
·Linux系统启动时间的极限
·从源代码中打造一个最小的
·Linux操作系统下 Apache安
·关于Linux系统下加载NTFS
·介绍使用Yum自动更新Linux
·Linux系统下的共享文件夹
·Debian下系统时间比正常时
·Apache2 httpd.conf 中文
·apache 2.2.2 + PHP5.1.4
·Apache Beehive——Worksh
·Apache web服务器架设实战
·Apache Web让JSP“动”起

设为首页 - 加入收藏 - 版权声明 - 广告服务 - 关于我们 - 联系我们 - 友情连接
Copyright © 2007 All rights reserved OKLinux.Cn 版权所有
合作联系 QQ:18743986 Email:arlan8005#163.com