您的(de)位置: 新聞資訊 > 行(xíng)業(yè)動态 > 正文(wén)

《輕松設置 Nginx 免費(fèi)防火Ω¥™(huǒ)牆 User-Agent 白(bái)↔÷±名單》(圖文(wén))


來(lái)源:mozhe 2024-09-14

Nginx 作(zuò)為(wèi)一(yī)款高(gāoσ< )性能(néng)的(de)開(kāi)源 Web 服務器(λ ‍♠qì)軟件(jiàn),在企業(yè)項目中被廣泛應用(yòng)。在當今的(®&✔de)網絡環境下(xià),服務器(qì)‍≈∏面臨著(zhe)來(lái)自(zì)全球各地(dì)的(de)訪問(wè‌®n),其中不(bù)乏惡意用(yòng)戶和(hé)惡意程序的(de)↑©‌攻擊。因此,防火(huǒ)牆及白(bái)名單設置對(duì)于服務器(qì₩¥)的(de)安全至關重要(yào)。
防火(huǒ)牆可(kě)以限制(zhì) IP 訪問(wè↓∑→n),隻允許需要(yào)的(de) IP 訪問(wèn)。通(tō✔$☆ng)過設置防火(huǒ)牆,可(kě)以有(yǒu)™≥λ₩效防止未經授權的(de)外(wài)部訪問(wèn),保護服務器(qì)免受惡Ω☆∏±意攻擊。例如(rú),可(kě)以使用(yòng) ipta≠♥¶αbles、ufw 等工(gōng)具進行(xíng)設置,限制(zhì)特定♠∑' IP 地(dì)址或 IP 段的(de)訪問(wèn)。₩₽✔同時(shí),為(wèi) Nginx 服務器(qì)配置 SS'<ε₹L/TLS 證書(shū),加強數(shù)據傳輸加密,采用(yòn₽®g) HTTPS 訪問(wèn),有(yǒu)效防止♣©∞₽數(shù)據被竊聽(tīng)和(hé♣δ)篡改。
白(bái)名單則是(shì)一(yī)種更為(wèi)嚴格的(σ♠♥de)訪問(wèn)控制(zhì)機(jī)制(zhì),可(kě)以限制(z←↑"₹hì)特定的(de)用(yòng)戶或請(qǐng)求能(néng)順利訪問( "wèn)服務器(qì)。通(tōng)過設置白(bái)名單,可(kě)以↓§•确保隻有(yǒu)特定的(de) IP 地(dì)址、域>₩&名或用(yòng)戶能(néng)夠訪問(wèn)服務&↔×₹器(qì),阻止潛在的(de)風(fēng)險。例如(rπ< ​ú),可(kě)以使用(yòng) Ngi₩☆÷λnx 的(de) Geo 模塊來(lái)♠ΩΩ≠設置白(bái)名單,隻允許中國(guó)和(hé)美(měi±π∑)國(guó)的(de)訪客訪問(wèn)網站(zhàn),其他(≈±tā)國(guó)家(jiā)的(de)訪客将被拒絕訪問(wèn)。
據統計(jì),目前互聯網無時(shí)無刻都(dōu)有(yǒπ♠u)各種掃描、探測、攻擊著(zhe)服務器(q♠‌$ ì)。這(zhè)些(xiē)攻擊者不(bù)會(huì)輕易放(fàn≈Ωγg)過每一(yī)個(gè)機(jī)會(huì)ε&≠',按照(zhào) IP 段一(yī)路(lù)掃描,隻要(≤®♥♠yào)是(shì)雲服務器(qì)的(de)公網 IP 提供對™☆(duì)外(wài)訪問(wèn),就(jiù)避不(bù)開(k§ ​™āi)探測和(hé)被攻擊。因此,下(xià)載寶塔面闆 -£♥↑ nginx 防火(huǒ)牆插件(jiàn)就(jiù)有↔♥♥(yǒu)了(le)安全保障,能(néng)有(yǒu)效防止$β sql 注入 /xss/ 一(yī)句話(huà)♠Ω'木(mù)馬等常見(jiàn)滲透攻擊。
總之,Nginx 防火(huǒ)牆及白(bái)名 γ$ 單設置對(duì)于服務器(qì)的(de)安©δ全至關重要(yào)。通(tōng)過設置防火(hu≠™₽ǒ)牆和(hé)白(bái)名單,可(kě)以≈×♥有(yǒu)效保護服務器(qì)免受惡意攻擊,确保特定™&¥∑用(yòng)戶或請(qǐng)求能(néng)順利訪問(wèn)服務→ ✘器(qì),為(wèi)企業(yè)項目的(de)®Ω穩定運行(xíng)提供有(yǒu)力保障。

二、白(bái)名單設置方法

(一(yī))定義黑(hēi)名單或白(bái)名單


在 Nginx 的(de) conf 目錄下(xià)建立 blo₹¥∏ckip.conf 文(wén)件(jiàn),☆∏•是(shì)定義黑(hēi)名單或白(bái)名單✔×的(de)一(yī)種方法。格式如(rú)下(xià):π₽屏蔽單個(gè) ip 訪問(wèn)可(kě)以使用(yòng)d₩γeny IP;允許單個(gè) ip 訪問(wèn)用(↕Ω✔"yòng)allow IP;屏蔽所有(yǒu) ip 訪問(‍βπwèn)為(wèi)deny all;允&←&​許所有(yǒu) ip 訪問(wèn)是(shì)allow all。如(r±♦→ú)果想實現(xiàn)除了(le)幾個(g£±✘è) IP 外(wài)其他(tā)全部±♦拒絕的(de)效果,可(kě)以在 block♠<ip.conf 中這(zhè)樣寫:先允許特定的(de) IP,γ£∑如(rú)allow 1.1.1.1、allow 1.1.1.2,然後再使用(yòng)deny all。在 ngi→₩≈λnx.conf 中添加配置時(shí),可(kπ♣δλě)以将include blocksip.conf放(fàng)≠±到(dào)http、server、locat'φγion、limit_except語句塊中,需注意相(xiàng)★♥♥£對(duì)路(lù)徑。例如(rú),若要(yào)實現(φ"εxiàn)所有(yǒu)網站(zhàn)屏蔽 IP 的(de)方法,¶≠σ把include blocksip.conf放(fàng)≤‍ 到(dào)http {}語句塊;若要(yào)單獨屏• 蔽某個(gè)網站(zhàn)的(de) ♠₩ IP,則把include blocksip.conf放(fàng)到("σdào)該網站(zhàn)對(duì)應的(de)server{}β±語句塊。

(二)黑(hēi)白(bái)名單作(zuò)用(yòn ♥✘g)範圍


白(bái)名單和(hé)黑(hēi)名單>&能(néng)在http{}、server{}、locatio<∞∑≥n{}下(xià)使用(yòng),功能(néngβγ♣)默認是(shì)關閉的(de)。配置格式為(wèi)配置關鍵字on/off→±,其中配置關鍵字有(yǒu)white_list↓γ÷與black_list,分(fēn)别用(yòng)來>♣(lái)表示白(bái)名單與黑(hēi♣₩₩)名單。例如(rú):white_list wh♣₩ite1 on表示白(bái)名單white1在απ∏整個(gè)http{}中都(dōu)開(kāi)啓;bl₽→ack_list black1 on表示黑(hēi)名單black1在整個(g∑≥€→è)http{}中都(dōu)開(kāi)啓。在server¥×‌{}和(hé)location{}中使用(yòng)方式類似。≈↑"

(三)配置接口說(shuō)明(míng)


http 配置接口包括以下(xià)內(nèi)容:
  1. 查看(kàn)黑(hēi)白(bái)名單定義情況可(kě)以©≤∏&通(tōng)過http://xxx/sec_config‍β,返回結果包含版本信息、代碼以及黑(hēi)白(bái)§×名單的(de)配置信息。
  1. 查看(kàn)特定zone_name為(wèi)white的(de)l¥₩ist_path中的(de)具體(tǐ)內(nèi)容可(kě€✔γ)以使用(yòng)http://xxx/sec_config?zone_↓σ→φname=white。
  1. 向特定zone_name中增加 IP,如(rú)向zone_name←α為(wèi)white中增加192.168.141.23可(kě)以使用(yòng)http://xxx/sec_∑<config?zone_name=white&amπ ‌p;add_item=192.168.141.23
  1. 在特定zone_name中删除 IP,如(rú)在zone_name為(w‍↔★èi)white中删除192.168.141.23可(kě)以使用(yòng)http:/↓✘¥/xxx/sec_config?zone_name=white&a×↓↕mp;delete_item=192.168.141.23。查看(kàn)配置方法還(hái)可(kě)以使用(yòng)htt ↑ p://xxx/sec_config?for_each。

(四)動态黑(hēi)名單設置


要(yào)使用(yòng)動态黑(hēi"≈∑₩)名單功能(néng),必須對(duì)ngx_http_limit_rδ÷eq_module.c進行(xíng)patch。在ngx_http_ >limit_req_module.c中增加#includ¶σ e <white_black_list.hφ★¶>,并修改代碼找到(dào)特定位置,在其下(xià)面δ©<增加ngx_black_add_item_interface(r<Ω£≠,1)。配備關鍵字為(wèi)dyn_black,✔©≠≥格式為(wèi)dyn_black $zone_nam♥Ω→βe time,比如(rú)dyn_black black 6♣'0表示禁止訪問(wèn) 60 秒(miǎo),60 秒(miǎo)後自←•(zì)動解除。注意必須要(yào)配置blac✘♠k_list。

(五)安裝相(xiàng)關模塊


安裝ngx_lua_waf防火(huǒ)牆的(de)各種依賴及模塊的§α(de)步驟如(rú)下(xià):
  1. 下(xià)載相(xiàng)關模塊:
    • cd /usr/src/,然後依次下(xià)載luajit2、lua-•←‌cjson、ngx_devel_kit、lua-nginx-modu↕♦¶☆le等模塊。
  1. 編譯安裝luajit:
    • cd luajit-2.1,make -j2 &&a÷φ©mp; make install,echo &lσ☆"squo;/usr/local/lib’ >&®♣'gt; /etc/ld.so.conf.d/local.conf,ldconfig。
  1. 編譯安裝lua-cjson:
    • cd /usr/src/lua-cjso§✘©≤n,export LUA_INCLUDE_DIR=/usr/loc✘£→al/include/luajit-2.1,makeβδ -j2 && make install。
  1. 設置LUAJIT環境變量:
    • export LUAJIT_LIB=/usr/local/¥↕£lib,export LUAJIT_INC=​σ←/usr/local/include/luajit-2.1。δ♣
  1. 編譯nginx時(shí)加上(shàng)兩個(gè)模塊:&n§‍γ£dash;add-module=../lua-nginx-€±αmodule、–add-module=../ngx_‌δ¥devel_kit。
  1. 下(xià)載配置ngx_lua_waf:
    • cat >/usr/local/ngi♣₹§nx/conf/waf.conf << EO§←F,lua_shared_dict lim☆♥it20m;,lua_package_path "/usr‍≤≠/local/nginx/conf/waf/?.lua"γε;,init_by_lua_file"/usr/local/nginσ✘↑x/conf/waf/init.lua&qu✔®±$ot;;,access_by_lua_file&quo>€£t;/usr/local/nginx/conf¥‌£/waf/access.lua";,EOF。
    • mkdir -p /usr/local/​★nginx/logs/waf,chown www-data:www-data©ε /usr/local/nginx/logs/w←£×±af。

(六)測試驗證


啓動nginx并訪問(wèn)特定網址以查看(kàn)防火(huǒ)牆提€γ♥↔示。例如(rú)訪問(wèn)http://192.168.31.91/?a=a.sql,就(jiù)可(kě)以看(kàn)到(dào)♠¶‌防火(huǒ)牆提示。通(tōng)過這(zh×₩"≠è)種方式可(kě)以驗證防火(huǒ)牆是(shì)否正常工(γ ≥gōng)作(zuò)。

三、總結與展望


Nginx 免費(fèi)防火(huǒ)牆的(δ®←de) User-Agent 白(bái)名單設置在服務器(qì)安全防護♣↔÷♥中起著(zhe)至關重要(yào)的(de)作(zuò)用(yò£←↑↑ng)。通(tōng)過對(duì) User-Ag♠≠ent 的(de)篩選,可(kě)以有(¶♥yǒu)效阻止潛在的(de)惡意請(qǐng)求,為(♣→'↔wèi)服務器(qì)的(de)穩定運行(xíng)提供有(yǒu)力↓≠ ✔保障。
User-Agent 白(bái)名單的£€(de)設置具有(yǒu)很(hěn)強的(de)實用(yò≠ε™ng)性。例如(rú),在某些(xiē)特定♦©的(de)業(yè)務場(chǎng)景下(xià),隻允許特定類型的(dσφe)客戶端訪問(wèn)服務器(qì),可(k←§ě)以通(tōng)過設置 User-Agentφ€←π 白(bái)名單來(lái)實現(xiàn)‍✔£。同時(shí),結合其他(tā)的(de)安全設置,如(rú) IP€‍∏ 白(bái)名單、URL 白(bái)名單等δ↕ ,可(kě)以構建一(yī)個(gè)更加嚴密的(☆↑♥λde)安全防護體(tǐ)系。
在實際應用(yòng)中,讀(dú)者可(kě€♦​&)以根據自(zì)己的(de)需求進行(xíng)靈活配置。根據不(b≤♦ù)同的(de)業(yè)務場(chǎng)景和(hé)安全要(yào)求,‌™φ選擇合适的(de)白(bái)名單規則,确保服務器 ←≥☆(qì)的(de)安全。同時(shí),随著(z↑≈★♠he)網絡安全形勢的(de)不(bù)斷變化(huà),我們也(yě)需要(☆αyào)不(bù)斷地(dì)更新和(hé)完善白(bái)名單∏≠設置,以适應新的(de)安全挑戰。
總之,Nginx 免費(fèi)防火(huǒ)牆的(de) U≈≈∞ser-Agent 白(bái)名單設置是(s¶←hì)服務器(qì)安全防護的(de)重要(y'±∞ào)手段之一(yī)。通(tōng)過合理(lǐ₹​↔)的(de)設置和(hé)靈活的(de)配置,可(kě)以為(wèi)服務器↕≠(qì)的(de)安全提供有(yǒu)力保障,為(wèΩ♣i)企業(yè)的(de)業(yè)務發展保駕護航。
 

墨者安全 防護盾

墨者安全作(zuò)為(wèi)專業(yè)級别安全防護專家↑¥α‌(jiā),在應對(duì) Webshell 風(fēng)險隐患♦β方面展現(xiàn)出了(le)卓越的(de)>$≥能(néng)力。其擁有(yǒu)全面的(de)檢測機(jī)制(zhì)∏↓‌,能(néng)夠精準識别 Webshell 的(☆∑£✔de)各種類型和(hé)變體(tǐ),無論是(shì)複雜(zá)的(de±↕)大(dà)馬,還(hái)是(shì)隐蔽的(Ω$↓de)內(nèi)存馬,都(dōu)難逃其敏銳的(de)監測。
墨者安全防護盾具備強大(dà)的(de)實時(shí)監φ♣控功能(néng),對(duì)服務器(qì)的(de)各項活動進行​♠(xíng) 7*24 小(xiǎo)時(shí)不(bù)間(ji↑•σān)斷的(de)監視(shì)。一(yī)旦£♠&發現(xiàn)任何可(kě)疑的(deλ"♦φ) Webshell 活動迹象,立即發出警報(bào),↔‌≠并迅速采取隔離(lí)和(hé)清除措施,将風(fēng)險扼殺在β↓Ω×萌芽狀态。
在防護策略上(shàng),墨者安全防護盾采用(yòng)了(le)∑♦≠♦多(duō)層次的(de)防禦體(tǐ)系。不(bù)僅能(néng)夠 β€​在網絡層面阻擋外(wài)部的(de)惡意訪問(wè≥Ω‍Ωn)和(hé)攻擊,還(hái)能(néng)深入系統內(nèi)部,對(©&∞duì)服務器(qì)的(de)文(wén)件♣×>(jiàn)系統、進程等進行(xíng)深度檢查和(hé)保護,确保 Web≤♥γ♠shell 無法植入和(hé)運行(xíng)。
同時(shí),墨者安全防護盾擁有(yǒu)快(>$πkuài)速的(de)應急響應能(néng)力。→↕當 Webshell 攻擊事(shì)件(jià♥→¶n)發生(shēng)時(shí),專業(yè)的(de)安全團隊能(nπ♣'éng)夠迅速介入,進行(xíng)深入的(de)分§₽₹≥(fēn)析和(hé)處理(lǐ),最大(dà)程度減少(sΩ‌ ¥hǎo)攻擊帶來(lái)的(de)損失,并幫助用(yòng ‌±)戶快(kuài)速恢複服務器(qì)的(de)©™✔正常運行(xíng)。
墨者安全防護盾還(hái)注重用(yòng)戶教育和(hé)培訓,為(wè•♦φ✘i)用(yòng)戶提供關于 Webshelβ&↓l 防範的(de)專業(yè)知(zhī)識和(hé)最佳實踐,©&↔λ幫助用(yòng)戶提升自(zì)身(shēn)的£$≈(de)安全意識和(hé)防範能(néng)力,共同構建堅實的(de)網絡∑£✔£安全防線。
X

7x24 小(xiǎo)時(shí)

免費(fèi)技(jì)術(shù)支持

15625276999


-->