文章詳情頁
不解的nginx rewrite規則
瀏覽:110日期:2024-06-17 10:22:07
問題描述
上圖是我根據nginx最長匹配原則 配置的簡單范例, 目的是訪問 / 的時候全部拒絕, 但訪問 /hello 的時候能進行正常跳轉. 但是返現, 訪問 /hello 依舊403, 但是重寫日志里面記錄 nginx確實匹配到了我的規則, 為何還是返回給我403呢? 求大神解惑, 不甚感激!
問題解答
回答1:location / 可以匹配到所有的請求
你可以如下修改
location = / { deny all; }
語法規則: location [=|~|~*|^~] /uri/ { … }= 開頭表示精確匹配^~ 開頭表示uri以某個常規字符串開頭,理解為匹配 url路徑即可。nginx不對url做編碼,因此請求為/static/20%/aa,可以被規則^~ /static/ /aa匹配到(注意是空格)。~ 開頭表示區分大小寫的正則匹配~* 開頭表示不區分大小寫的正則匹配!~和!~*分別為區分大小寫不匹配及不區分大小寫不匹配 的正則/ 通用匹配,任何請求都會匹配到
回答2:因為rewrite之后的 /test00 匹配到了 location /
你應該加一個 location ~ ^/test00 并開放訪問權限
相關文章:
1. docker-compose中volumes的問題2. java如何高效讀寫10G以上大文件3. android - viewpager問題PagerTabStrip樣式4. css - input元素的time控件無法選擇5. javascript - js判斷用戶的網絡能否上網?6. python 字符串匹配問題7. dockerfile - [docker build image失敗- npm install]8. javascript - 這里的這個函數是干嘛用的?9. mysql - SQL語句可以提供“查詢表,并至第100條結果為止”嗎?10. javascript - CSS圖片輪播顯示問題
排行榜
