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;
}
}