91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

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

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

在Nginx中怎么攔截特定用戶代理

發布時間:2022-04-29 16:59:49 來源:億速云 閱讀:150 作者:iii 欄目:大數據

這篇文章主要介紹“在Nginx中怎么攔截特定用戶代理”,在日常操作中,相信很多人在在Nginx中怎么攔截特定用戶代理問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對大家解答”在Nginx中怎么攔截特定用戶代理”的疑惑有所幫助!接下來,請跟著小編一起來學習吧!

在nginx中將特定用戶代理列入黑名單

要配置用戶代理阻擋列表,請打開你的網站的nginx配置文件,找到server定義部分。該文件可能會放在不同的地方,這取決于你的nginx配置或linux版本(如,/etc/nginx/nginx.conf,/etc/nginx/sites-enabled/<your-site>,/usr/local/nginx/conf/nginx.conf,/etc/nginx/conf.d/<your-site>)。

復制代碼 代碼如下:

    server {
        listen       80 default_server;
        server_name  xmodulo.com;
        root         /usr/share/nginx/html;
        ....
    }

在打開該配置文件并找到 server 部分后,添加以下 if 聲明到該部分內的某個地方。

復制代碼 代碼如下:

    server {
        listen       80 default_server;
        server_name  xmodulo.com;
        root         /usr/share/nginx/html;
        # 大小寫敏感的匹配
        if ($http_user_agent ~ (antivirx|arian) {
            return 403;
        } 

        #大小寫無關的匹配      

復制代碼 代碼如下:

    if ($http_user_agent ~* (netcrawl|npbot|malicious)) {
            return 403;
        }
        ....
    }  

如你所想,這些 if 聲明使用正則表達式匹配了任意不良用戶字符串,并向匹配的對象返回403 http狀態碼。 $http_user_agent是http請求中的一個包含有用戶代理字符串的變量。‘~'操作符針對用戶代理字符串進行大小寫敏感匹配,而‘~*'操作符則進行大小寫無關匹配。‘|'操作符是邏輯或,因此,你可以在 if 聲明中放入眾多的用戶代理關鍵字,然后將它們全部阻擋掉。

在修改配置文件后,你必須重新加載nginx以激活阻擋:  

 $ sudo /path/to/nginx -s reload

你可以通過使用帶有 “--user-agent” 選項的 wget 測試用戶代理阻擋。  

 $ wget --user-agent "malicious bot" http://<nginx-ip-address>

  在Nginx中怎么攔截特定用戶代理

    管理nginx中的用戶代理黑名單

目前為止,我已經展示了在nginx中如何阻擋一些用戶代理的http請求。如果你有許多不同類型的網絡爬蟲機器人要阻擋,又該怎么辦呢?

由于用戶代理黑名單會增長得很大,所以將它們放在nginx的server部分不是個好點子。取而代之的是,你可以創建一個獨立的文件,在該文件中列出所有被阻擋的用戶代理。例如,讓我們創建/etc/nginx/useragent.rules,并定義以下面的格式定義所有被阻擋的用戶代理的圖譜。

  $ sudo vi /etc/nginx/useragent.rules

復制代碼 代碼如下:

   map $http_user_agent $badagent {
            default         0;
            ~*malicious     1;
            ~*backdoor      1;
            ~*netcrawler    1;
            ~antivirx       1;
            ~arian          1;
            ~webbandit      1;
    } 

與先前的配置類似,‘~*'將匹配以大小寫不敏感的方式匹配關鍵字,而‘~'將使用大小寫敏感的正則表達式匹配關鍵字。“default 0”行所表達的意思是,任何其它文件中未被列出的用戶代理將被允許。

接下來,打開你的網站的nginx配置文件,找到里面包含 http 的部分,然后添加以下行到 http 部分某個位置。   

復制代碼 代碼如下:

   http {
        .....
        include /etc/nginx/useragent.rules
    } 

注意,該 include 聲明必須出現在 server 部分之前(這就是為什么我們將它添加到了 http 部分里)。

現在,打開nginx配置定義你的服務器的部分,添加以下 if 聲明:

復制代碼 代碼如下:

   server {
        ....
        if ($badagent) {
            return 403;
        }
        ....
    }  

最后,重新加載nginx。  

 $ sudo /path/to/nginx -s reload

現在,任何包含有/etc/nginx/useragent.rules中列出的關鍵字的用戶代理將被nginx自動禁止。

到此,關于“在Nginx中怎么攔截特定用戶代理”的學習就結束了,希望能夠解決大家的疑惑。理論與實踐的搭配能更好的幫助大家學習,快去試試吧!若想繼續學習更多相關知識,請繼續關注億速云網站,小編會繼續努力為大家帶來更多實用的文章!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

黑龙江省| 林周县| 小金县| 靖远县| 富锦市| 马边| 毕节市| 政和县| 鸡泽县| 宽甸| 鹤峰县| 长岭县| 麻阳| 铜陵市| 彝良县| 泗洪县| 桐梓县| 文安县| 岑溪市| 静乐县| 临朐县| 富源县| 镇坪县| 牟定县| 阿克陶县| 贵南县| 房产| 武清区| 顺义区| 曲周县| 天等县| 黎川县| 宽城| 乐平市| 石家庄市| 星座| 建阳市| 阿坝| 宝山区| 台北市| 磐安县|