nginx静态资源配置


解决EE工程中静态文件显示问题

在工程中本地测试没有问题,发现使用nginx配置了路径的页面,会获取不到相应页面的静态文件问题

静态文件的路径类似为: http://localhost:8080/salama/static/js/lib/jquery.js
引用此静态文件的实际路径为: http://localhost:8080/salama/userInfo/?log=aaa&gender=1&city=bj (访问此页面会传递部分参数,然后打开一个调查问卷页面)
现在给出一个二级域名: api.salama.com 直接使用域名能访问到页面,通过nginx的配置隐藏工程名称和第一级目录名称(salama/userInfo)

nginx的配置为:

 server {
        listen 80;
        server_name api.salama.com;
        location / {
                index index.html index.htm index.jsp;
                proxy_pass http://localhost:8080/salama/userInfo/;
        }
    }

这样配置访问对应页面没有问题,但是无法获取到静态资源文件.
在浏览器控制台看到的静态资源文件请求路径为:

http://api.salama.com/salama/static/js/lib/jquery.js

显然在api.salama.com返回的页面中是无法获取到个静态资源文件的,解决办法如下:

 server {
        listen 80;
        server_name api.salama.com;
        
        location / {
                index index.html index.htm index.jsp;
                proxy_pass http://localhost:8080/salama/userInfo/;
        }

        location /salama/static {
                # 这里可以直接写localhost:8080,nginx会把location后面的参数追加过来,还要注意不要乱添加 /  否则会导致无法访问
                proxy_pass http://localhost:8080;       
        }

    }

参考资料:https://www.nginx.com/resources/admin-guide/


免责声明!

本站转载的文章为个人学习借鉴使用,本站对版权不负任何法律责任。如果侵犯了您的隐私权益,请联系本站邮箱yoyou2525@163.com删除。



 
粤ICP备18138465号  © 2018-2025 CODEPRJ.COM