javascript - nginx反向代理靜態資源403錯誤?
問題描述
部署上線測試的Node項目,使用nginx反向代理時出現靜態資源403錯誤,本地配置正確,線上同樣的配置卻產生了錯誤.配置如下:
upstream nodeblog{server 127.0.0.1:3000;keepalive 65;}server {listen 443;ssl on;server_name ;ssl_certificate ;ssl_certificate_key ;ssl_protocols TLSv1 TLSv1.1 TLSv1.2;ssl_ciphers ;ssl_session_timeout 5m;ssl_prefer_server_ciphers on;location / {proxy_set_header X-Real-IP $remote_addr;proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;proxy_set_header Host $http_host;proxy_set_header X-Nginx-Proxy true;proxy_set_header Connection ’’;proxy_pass http://nodeblog;}location ~ .*.(css|js|jpg|png|gif)$ {alias '/root/nodeApp/public/';expires 3d;}}
按照提示設置了該目錄下所有文件777權限,依舊是403錯誤
問題解答
回答1:找到一個原因,因為是在root權限下操作的,可能是nginx沒有該目錄的權限.個人服務器因此也沒有分配其他用戶,所以打開nginx.conf中第一行user nobody修改為user root使得nginx以root權限運行.
這肯定不是好的解決方案,知識大致了解了,403的原因,nginx進程沒有當前靜態資源文件夾的相關權限,需要單獨制定nginx對該目錄的權限.希望有好的解決方案
回答2:原因是錯誤運用了alias指令。官方文檔
If alias is used inside a location defined with a regular expressionthen such regular expression should contain captures and alias shouldrefer to these captures (0.7.40)http://nginx.org/r/alias
試下以下配置
location ~ .*.(css|js|jpg|png|gif)$ {alias '/root/nodeApp/public/$1';expires 3d;}
相關文章:
1. 管理員信息修改時的密碼問題2. html5 - 為什么使使用vue cli 腳手架,post-css 沒有自動對css3屬性自動添加瀏覽器前綴呢?3. angular.js - 輸入郵箱地址之后, 如何使其自動在末尾添加分號?4. android - RxJava 中有根據條件執行不同函數的操作符嗎?5. javascript - 如何使用nodejs 將.html 文件轉化成canvas6. java如何生成token?7. javascript - 后臺管理系統左側折疊導航欄數據較多,怎么樣直接通過搜索去定位到具體某一個菜單項位置,并展開當前菜單8. javascript - html5的data屬性怎么指定一個function函數呢?9. 如何解決docker宿主機無法訪問容器中的服務?10. mysql - 電商如何存儲營業額數據
