首頁 php教程 php手册 Linux系统Apache用户授权和访问控制

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

Jun 21, 2016 am 09:00 AM
directory htaccess httpd limit

用户授权和访问控制

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

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

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

<ccid_code><directory> # 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</ccid_code>
登入後複製

2、创建.htaccess文件內容

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

<ccid_code>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></ccid_code>
登入後複製

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文件,达到的提高服务效率的目的。

<ccid_code><directory></directory> AllowOverride None  <directory> AllowOverride All </directory></ccid_code>
登入後複製

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

<ccid_code><directory> AllowOverride FileInfo Indexes IncludesNOEXEC </directory></ccid_code>
登入後複製

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

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

<ccid_code><files .htaccess> order allow,deny deny from all </files></ccid_code>
登入後複製

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

<ccid_code><files> Order deny, allow Deny from all </files></ccid_code>
登入後複製

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

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

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

<ccid_code><location> order deny,allow deny from all allow from .domain.com </location></ccid_code>
登入後複製

如果你要授于相应权限的机器没有公开的域名,请在你的/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文件的内容如下:

<ccid_code>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></ccid_code>
登入後複製



本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

Active Directory 使用者和電腦遺失 [以 3 種方式修復] Active Directory 使用者和電腦遺失 [以 3 種方式修復] Apr 20, 2023 pm 01:25 PM

ActiveDirectory使用者和電腦(ADUC)遺失是許多WindowsPro使用者報告的最令人沮喪的問題之一。 ADUC是一個令人難以置信的MMC管理單元,它使管理員能夠管理MicrosoftActiveDirectory。但是,由於某種原因,它在Windows伺服器或Enterprise/Pro版本中缺失。讓我們深入了解它丟失的原因以及我們如何修復它。 Windows11是否有ActiveDirectory? ActiveDirectory是任何想要管理遠端

Laravel中take和limit的使用方法詳解 Laravel中take和limit的使用方法詳解 Mar 10, 2024 pm 05:51 PM

《Laravel中take和limit的使用方法詳解》在Laravel中,take和limit是兩個常用的方法,用於在資料庫查詢中限制傳回的記錄數。雖然它們的作用類似,但在具體的使用場景中有一些細微的區別。本文將詳細解析這兩個方法的用法,並提供具體的程式碼範例。一、take方法在Laravel中,take方法用來限制傳回的記錄數,通常結合orderBy法一起

深入探討Laravel中take和limit的不同之處 深入探討Laravel中take和limit的不同之處 Mar 10, 2024 pm 01:00 PM

在Laravel中,我們常常用到一些方法來限制查詢結果的數量,其中包含take和limit兩個方法。雖然它們都可以用來限制查詢結果的數量,但它們之間確實有一些細微的差異。在本文中,我們將深入探討take和limit在Laravel的不同之處,並透過具體的程式碼範例來加以說明。首先,讓我們來看看take方法。 take方法是Eloquent的一部分,通常用於

Laravel中take和limit的功能及用法對比 Laravel中take和limit的功能及用法對比 Mar 09, 2024 pm 09:09 PM

Laravel中take和limit是兩種常用的方法,用來限制查詢結果集的數量。雖然它們在功能上有一定的相似之處,但在使用方式和一些細節上有所不同。本文將對這兩種方法的功能及用法進行詳細對比,同時提供具體的程式碼範例,幫助讀者更好地理解它們之間的差異和如何正確地應用。 1.take方法take方法是LaravelEloquent查詢建構器中

如何使用Java中的Stream的limit和skip函數進行流程操作 如何使用Java中的Stream的limit和skip函數進行流程操作 Jun 26, 2023 pm 03:55 PM

Java8中引入了StreamAPI,它能夠大幅簡化對集合的操作。 Stream類別提供了許多用於操作流程的函數式方法,包括過濾、映射、合併等等。其中,limit和skip是用於流操作中限制元素數量的兩個函數。一、limit函數limit函數用來限制流中元素的數量,它接受一個long類型的參數n,表示限制的數量。呼叫limit函數後,傳回一個新的流,它只包含

最後幻想7limit怎麼存 最後幻想7limit怎麼存 Mar 07, 2024 pm 06:40 PM

玩家在最終幻想7中進行遊戲時可以透過積攢limit使用極限技,可以造成巨大傷害或提供強大的支援效果,玩家可以透過受到傷害、攻擊敵人、被擊中連擊等方式獲得limit。最後幻想7limit怎麼存1、受傷當角色受到敵方攻擊或隊友受到攻擊時,limit條會逐漸成長。受到的傷害越多,limit條填得越快。 2.攻擊敵人主動攻擊敵人也能增加limit條的填充速度。使用普通攻擊、技能或魔法都能累積limit。 3.被擊中連擊角色連續被敵人攻擊時,limit條的填充速度會加快。可以透過吸引敵人的注意或使用持

不同的MySQL分頁實作方式 不同的MySQL分頁實作方式 Feb 19, 2024 pm 03:26 PM

MySQL分頁方法有哪些,需要具體程式碼範例MySQL是一種關係型資料庫管理系統,為了提高查詢效率和減少資料傳輸量,分頁查詢是一個非常常見的需求。 MySQL提供了多種分頁方法,以下將詳細介紹這些方法,並提供具體的程式碼範例。使用LIMIT子句分頁:LIMIT子句用來限制查詢結果的傳回行數。它有兩個參數,第一個參數指定傳回結果的起始偏移位置(從0開始計數),第二個

解決Yum Httpd無法解析PHP的問題 解決Yum Httpd無法解析PHP的問題 Mar 22, 2024 pm 01:06 PM

解決YumHttpd無法解析PHP的問題,需要具體程式碼範例在建置網站時,經常會遇到Yum安裝的Httpd無法解析PHP的問題,導致無法正常存取網站頁面。這個問題一直困擾著許多網站管理員和開發者,在本文中,我們將針對這個問題提供一些解決方案,並給出具體的程式碼範例。首先,我們需要明確問題的根源。 Httpd無法解析PHP通常是因為缺乏必要的PHP模組或設定不正確

See all articles