溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

Linux下怎么安全配置apache

發(fā)布時(shí)間:2022-01-27 14:09:51 來(lái)源:億速云 閱讀:171 作者:iii 欄目:開發(fā)技術(shù)

這篇文章主要介紹“Linux下怎么安全配置apache”,在日常操作中,相信很多人在Linux下怎么安全配置apache問題上存在疑惑,小編查閱了各式資料,整理出簡(jiǎn)單好用的操作方法,希望對(duì)大家解答”Linux下怎么安全配置apache”的疑惑有所幫助!接下來(lái),請(qǐng)跟著小編一起來(lái)學(xué)習(xí)吧!

Apache具有靈活的設(shè)置,所有Apache的安全特性都要經(jīng)過(guò)周密的設(shè)計(jì)與規(guī)劃,進(jìn)行認(rèn)真地配置才能夠?qū)崿F(xiàn)。Apache安全配置包括很多層面,有運(yùn)行環(huán)境、認(rèn)證與授權(quán)設(shè)置等。

Linux下怎么安全配置apache

1.Apache具有靈活的設(shè)置

所有Apache的安全特性都要經(jīng)過(guò)周密的設(shè)計(jì)與規(guī)劃,進(jìn)行認(rèn)真地配置才能夠?qū)崿F(xiàn)。Apache安全配置包括很多層面,有運(yùn)行環(huán)境、認(rèn)證與授權(quán)設(shè)置等。Apache的安裝配置和運(yùn)行示例如下:

  • 1 修改apache的版本信息,使外部訪問看到的apache信息是經(jīng)過(guò)偽裝或錯(cuò)誤的,這個(gè)可以盡可能的保證apache的安全。
  • 2 建立安全的apache的目錄結(jié)構(gòu)。ServerRoot DocumentRoot ScripAlias Customlog Errorlog 均放在單獨(dú)的目錄環(huán)境中。以上主要目錄相互獨(dú)立并且不存在父子邏輯關(guān)系。
  • 3 ServerRoot目錄只能具有管理權(quán)限用戶訪問;DocumentRoot能夠被管理Web站點(diǎn)內(nèi)容的用戶訪問和使用Apache服務(wù)器的Apache用戶和Apache用戶組訪問;只有admin組的用戶可以訪問日志目錄。 各個(gè)目錄設(shè)置獨(dú)立的權(quán)限
  • 4 禁止默認(rèn)訪問的存在,只對(duì)指定的目錄開啟訪問權(quán)限。
  • 5 更改apache的默認(rèn)路徑,單獨(dú)建立路徑提供apache文件的存放
  • 6 通過(guò)使用例如“Apache DoS Evasive Maneuvers Module ”等工具來(lái)實(shí)現(xiàn)Apache服務(wù)器對(duì)DoS攻擊的防范。其工具可以快速拒絕來(lái)自相同地址對(duì)同一URL的重復(fù)請(qǐng)求。
  • 7 以Nobody用戶運(yùn)行 一般情況下,Apache是由Root 來(lái)安裝和運(yùn)行的。如果Apache Server進(jìn)程具有Root用戶特權(quán),那么它將給系統(tǒng)的安全構(gòu)成很大的威脅,應(yīng)確保Apache Server進(jìn)程以最可能低的權(quán)限用戶來(lái)運(yùn)行。通過(guò)修改httpd.conf文件中的下列選項(xiàng),以Nobody用戶運(yùn)行Apache 達(dá)到相對(duì)安全的目的。

2、ServerRoot目錄的權(quán)限

為了確保所有的配置是適當(dāng)?shù)暮桶踩?,需要?yán)格控制Apache 主目錄的訪問權(quán)限,使非超級(jí)用戶不能修改該目錄中的內(nèi)容。Apache 的主目錄對(duì)應(yīng)于Apache Server配置文件httpd.conf的Server Root控制項(xiàng)中,應(yīng)為:

Server Root /usr/local/apache

3、SSI的配置

在配置文件access.conf 或httpd.conf中的確Options指令處加入Includes NO EXEC選項(xiàng),用以禁用Apache Server 中的執(zhí)行功能。避免用戶直接執(zhí)行Apache 服務(wù)器中的執(zhí)行程序,而造成服務(wù)器系統(tǒng)的公開化。

Options Includes Noexec

4、阻止用戶修改系統(tǒng)設(shè)置

在Apache 服務(wù)器的配置文件中進(jìn)行以下的設(shè)置,阻止用戶建立、修改 .htaccess文件,防止用戶超越能定義的系統(tǒng)安全特性。

AllowOveride None
Options None
Allow from all

然后再分別對(duì)特定的目錄進(jìn)行適當(dāng)?shù)呐渲谩?/p>

5、改變Apache 服務(wù)器的確省訪問特性

Apache 的默認(rèn)設(shè)置只能保障一定程度的安全,如果服務(wù)器能夠通過(guò)正常的映射規(guī)則找到文件,那么客戶端便會(huì)獲取該文件,如http://local host/~ root/ 將允許用戶訪問整個(gè)文件系統(tǒng)。在服務(wù)器文件中加入如下內(nèi)容:

order deny,ellow
Deny from all

將禁止對(duì)文件系統(tǒng)的缺省訪問。

6、CGI腳本的安全考慮

CGI腳本是一系列可以通過(guò)Web服務(wù)器來(lái)運(yùn)行的程序。為了保證系統(tǒng)的安全性,應(yīng)確保CGI的作者是可信的。對(duì)CGI而言,最好將其限制在一個(gè)特定的 目錄下,如cgi-bin之下,便于管理;另外應(yīng)該保證CGI目錄下的文件是不可寫的,避免一些欺騙性的程序駐留或混跡其中;如果能夠給用戶提供一個(gè)安全 性良好的CGI程序的模塊作為參考,也許會(huì)減少許多不必要的麻煩和安全隱患;除去CGI目錄下的所有非業(yè)務(wù)應(yīng)用的腳本,以防異常的信息泄漏。 以上這些常用的舉措可以給Apache Server 一個(gè)基本的安全運(yùn)行環(huán)境,顯然在具體實(shí)施上還要做進(jìn)一步的細(xì)化分解,制定出符合實(shí)際應(yīng)用的安全配置方案。 Apache Server基于主機(jī)的訪問控制 Apache Server默認(rèn)情況下的安全配置是拒絕一切訪問。假定Apache Server內(nèi)容存放在/usr/local/apache/share 目錄下,下面的指令將實(shí)現(xiàn)這種設(shè)置:

Deny from all
Allow Override None

則禁止在任一目錄下改變認(rèn)證和訪問控制方法。 同樣,可以用特有的命令Deny、Allow指定某些用戶可以訪問,哪些用戶不能訪問,提供一定的靈活性。當(dāng)Deny、Allow一起用時(shí),用命令Order決定Deny和Allow合用的順序,如下所示:

1、 拒絕某類地址的用戶對(duì)服務(wù)器的訪問權(quán)(Deny)

如:Deny from all
Deny from test.cnn.com
Deny from 204.168.190.13
Deny from 10.10.10.0/255.255.0.0

2、 允許某類地址的用戶對(duì)服務(wù)器的訪問權(quán)(Allow)

如:Allow from all
Allow from test.cnn.com
Allow from 204.168.190.13
Allow from 10.10.10.0/255.255.0.0

Deny和Allow指令后可以輸入多個(gè)變量。

3、簡(jiǎn)單配置實(shí)例:

Order Allow, Deny
Allow from all
Deny from www.test.com

指想讓所有的人訪問Apache服務(wù)器,但不希望來(lái)自www.test.com的任何訪問。

Order Deny, AllowDeny from allAllow from test.cnn.com

指不想讓所有人訪問,但希望給test.cnn.com網(wǎng)站的來(lái)訪。 Apache Sever的用戶認(rèn)證與授權(quán) 概括的講,用戶認(rèn)證就是驗(yàn)證用戶的身份的真實(shí)性,如用戶帳號(hào)是否在數(shù)據(jù)庫(kù)中,及用戶帳號(hào)所對(duì)應(yīng)的密碼是否正確;用戶授權(quán)表示檢驗(yàn)有效用戶是否被許可訪 問特定的資源。在Apache中,幾乎所有的安全模塊實(shí)際上兼顧這兩個(gè)方面。從安全的角度來(lái)看,用戶的認(rèn)證和授權(quán)相當(dāng)于選擇性訪問控制。 建立用戶的認(rèn)證授權(quán)需要三個(gè)步驟:

1、建立用戶庫(kù)

用戶名和口令列表需要存在于文件(mod_auth模塊)或數(shù)據(jù)庫(kù)(mod_auth_dbm模塊)中。基于安全的原因,該文件不能存放在文擋的根目 錄下。如,存放在/usr/local/etc/httpd下的users文件,其格式與UNIX口令文件格式相似,但口令是以加密的形式存放的。應(yīng)用程 序htpasswd可以用來(lái)添加或更改程序: htpasswd –c /usr/local/etc/httpd/users martin -c表明添加新用戶,martin為新添加的用戶名,在程序執(zhí)行過(guò)程中,兩次輸入口令回答。用戶名和口令添加到users文件中。產(chǎn)生的用戶文件有如下的形式:

martin:WrU808BHQai36jane:iABCQFQs40E8Mart:FadHN3W753sSU

第一域是用戶名,第二個(gè)域是用戶密碼。

2、配置服務(wù)器的保護(hù)域

為了使Apache服務(wù)器能夠利用用戶文件中的用戶名和口令信息,需要設(shè)置保護(hù)域(Realm)。一個(gè)域?qū)嶋H上是站點(diǎn)的一部分(如一個(gè)目錄、文檔等) 或整個(gè)站點(diǎn)只供部分用戶訪問。在相關(guān)目錄下的.htaccess文件或httpd.conf ( acces.conf ) 中的段中,由AuthName來(lái)指定被保護(hù)層的域。在.htaccess文件中對(duì)用戶文件有效用戶的授權(quán)訪問及指定域保護(hù)有如下指定:

AuthName “restricted stuff”
Authtype Basic
AuthUserFile /usr/local/etc/httpd/users
Require valid-user

其中,AuthName指出了保護(hù)域的域名(Realm Name)。valid-user參數(shù)意味著user文件中的所有用戶都是可用的。一旦用戶輸入了一個(gè)有效的用戶/口令時(shí),同一個(gè)域內(nèi)的其他資源都可以利 用同樣的用戶/口令來(lái)進(jìn)行訪問,同樣可以使兩個(gè)不同的區(qū)域共用同樣的用戶/口令。

3、告訴服務(wù)器哪些用戶擁有資源的訪問權(quán)限

如果想將一資源的訪問權(quán)限授予一組客戶,可以將他們的名字都列在Require之后。最好的辦法是利用組(group)文件。組的操作和標(biāo)準(zhǔn)的UNIX的組的概念類似,任一個(gè)用戶可以屬于一個(gè)和數(shù)個(gè)組。這樣就可以在配置文件中利用Require對(duì)組賦予某些權(quán)限。如:

Require group staff
Require group staff admin
Require user adminuser

指定了一個(gè)組、幾個(gè)組或一個(gè)用戶的訪問權(quán)限。

到此,關(guān)于“Linux下怎么安全配置apache”的學(xué)習(xí)就結(jié)束了,希望能夠解決大家的疑惑。理論與實(shí)踐的搭配能更好的幫助大家學(xué)習(xí),快去試試吧!若想繼續(xù)學(xué)習(xí)更多相關(guān)知識(shí),請(qǐng)繼續(xù)關(guān)注億速云網(wǎng)站,小編會(huì)繼續(xù)努力為大家?guī)?lái)更多實(shí)用的文章!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI