網站首頁 Linux教程 正文
Nginx 是一個高性能的 HTTP 和反向代理服務,目前很大一部分網站均使用了 Nginx 作為 WEB 服務器,Nginx 雖然非常強大,但默認情況下并不能阻擋惡意訪問,整理了一份常用的 Nginx 的屏蔽規則,希望對各位站長有所幫助。
在開始之前,請備份你的 Nginx 配置,修改完畢后需要重載一次 Nginx 的,否則不會生效。
如無特殊注明,下面命令均添加到 server 段內:
一、防止文件被下載
比如將網站數據庫導出到站點根目錄進行備份,很有可能也會被別人下載,從而導致數據丟失的風險。以下規則可以防止一些常規的文件被下載,可根據實際情況增減。
location ~ \.(zip|rar|sql|bak|gz|7z)$ {
return 444;
}
二、屏蔽非常見蜘蛛(爬蟲)
如果經常分析網站日志你會發現,一些奇怪的 UA 總是頻繁的來訪問網站,而這些 UA 對網站收錄毫無意義,反而增加服務器壓力,可以直接將其屏蔽。
if ($http_user_agent ~* (SemrushBot|python|MJ12bot|AhrefsBot|AhrefsBot|hubspot|opensiteexplorer|leiki|webmeup)) {
return 444;
}
禁止某個目錄執行腳本
比如網站上傳目錄,通常存放的都是靜態文件,如果因程序驗證不嚴謹被上傳木馬程序,導致網站被黑。以下規則請根據自身情況改為您自己的目錄,需要禁止的腳本后綴也可以自行添加。
#uploads|templets|data 這些目錄禁止執行 <a title="更多關于 PHP 的文章" target="_blank">PHP</a>
location ~* ^/(uploads|templets|data)/.*.(php|php5)$ {
return 444;
}
四、屏蔽某個 IP 或 IP 段
如果網站被惡意灌水或 CC 攻擊,可從網站日志中分析特征 IP,將其 IP 或 IP 段進行屏蔽。
#屏蔽 192.168.5.23 這個 IP
deny 192.168.5.23;
#屏蔽 192.168.5.* 這個段
denu 192.168.5.0/24;
上面規則報道查看 444 狀態碼而不是 403,
因為 444 狀態碼在 nginx 的中有特殊含義,nginx 的 444 狀態是直接由服務器中斷連接,不會向客戶端再返回任何消息。
比返回 403 更加暴力
相關推薦
- 2022-10-16 Flask快速實現分頁效果示例_python
- 2022-02-12 Flutter項目中有些依賴不支持64位的library的解決方式
- 2023-05-05 Python?pip更新的兩種方式詳解_python
- 2022-07-04 Python自動化辦公之清理重復文件詳解_python
- 2022-06-25 Python實現漸變色的水平堆疊圖_python
- 2022-03-15 ...has been blocked by CORS policy: Response to pr
- 2022-08-02 python監控日志中的報錯并進行郵件報警_python
- 2022-04-09 WPF中的數據模板用法介紹_基礎應用
- 欄目分類
- 最近更新
-
- window11 系統安裝 yarn
- 超詳細win安裝深度學習環境2025年最新版(
- Linux 中運行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎操作-- 運算符,流程控制 Flo
- 1. Int 和Integer 的區別,Jav
- spring @retryable不生效的一種
- Spring Security之認證信息的處理
- Spring Security之認證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權
- redisson分布式鎖中waittime的設
- maven:解決release錯誤:Artif
- restTemplate使用總結
- Spring Security之安全異常處理
- MybatisPlus優雅實現加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務發現-Nac
- Spring Security之基于HttpR
- Redis 底層數據結構-簡單動態字符串(SD
- arthas操作spring被代理目標對象命令
- Spring中的單例模式應用詳解
- 聊聊消息隊列,發送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠程分支