技术饭
Nginx设置alias的二级目录之后,首页访问正常,但是js、css、图片等静态文件出现404
Nginx设置alias的二级目录之后,首页访问正常,但是js、css、图片等静态文件出现404,之前配置了一个域名为pc访问域名,域名加个目录是访问后台,类似:a.com 是首页,a.com/admin 是后台,而且两个目录在同一个层级,但是alias配置之后一直找不到静态文件。
初始方案:
域名:a.com
前端:a.com 指向 /manyidea/www/svnweb/hdd/dist;
后台:a.com/dist 指向 /manyidea/www/svnweb/hddfront/dist;
两个目录在同一级,hddfront 不是在 hdd 里的二级目录
初始Nginx配置:
server {
listen 443;
server_name hddtest.many-idea.com;
ssl on;
index index.html index.htm index.php;
root /manyidea/www/svnweb/hdd/dist;
ssl_certificate /etc/nginx/cert/hdd/hddtest.many-idea.com.pem;
ssl_certificate_key /etc/nginx/cert/hdd/hddtest.many-idea.com.key;
ssl_session_timeout 5m;
ssl_ciphers ECDHE-RSA-AES128-GCM-SHA256:ECDHE:ECDH:AES:HIGH:!NULL:!aNULL:!MD5:!ADH:!RC4;
ssl_protocols TLSv1 TLSv1.1 TLSv1.2;
ssl_prefer_server_ciphers on;
client_max_body_size 100m;
#去掉$是为了不匹配行末,即可以匹配.php/,以实现pathinfo
#如果你不需要用到php5后缀,也可以将其去掉
location ~ .php
{
#原有代码
fastcgi_pass 127.0.0.1:9000;
fastcgi_index index.php;
include fastcgi_params;
#定义变量 $path_info ,用于存放pathinfo信息
set $path_info "";
#定义变量 $real_script_name,用于存放真实地址
set $real_script_name $fastcgi_script_name;
#如果地址与引号内的正则表达式匹配
if ($fastcgi_script_name ~ "^(.+?\.php)(/.+)$") {
#将文件地址赋值给变量 $real_script_name
set $real_script_name $1;
#将文件地址后的参数赋值给变量 $path_info
set $path_info $2;
}
#配置fastcgi的一些参数
fastcgi_param SCRIPT_FILENAME $document_root$real_script_name;
fastcgi_param SCRIPT_NAME $real_script_name;
fastcgi_param PATH_INFO $path_info;
}
location ~ .*\.(gif|jpg|jpeg|png|bmp|swf)$
{
expires 30d;
}
location ~ .*\.(js|css)?$
{
expires 1h;
}
location ~ ^(.*)\/\.svn\/{
deny all;
}
#伪静态规则
location / {
if (!-e $request_filename) {
rewrite ^(.*)$ /index.php?s=$1 last;
break;
}
}
#重定向后台目录
location /dist/ {
alias /manyidea/www/svnweb/hddfront/dist;
location ~ ^/dist/.*\.(js|css|gif|jpg|jpeg|png|bmp|swf|flv)?$ {
#root /manyidea/www/svnweb/hddfront/dist; //方案1 不行
alias /manyidea/www/svnweb/hddfront/dist; //方案2 不行
}
}
#日志
access_log /etc/nginx/access/logs/hdd.access.log;
error_log /etc/nginx/access/logs/hdd.error_log;
}
结果是:上面两种配置都行不通
经过多种测试,将配置文件里的 location ~ .*\.(js|css)?$ 与 location ~ .*\.(gif|jpg|jpeg|png|bmp|swf)$ 这两项注释之后,也就是无需设置静态文件的信息就没问题。这种解决方案不太理想。
最终解决方案:将 alias 改成 root,location /dist/ 这个 dist 要与指向的目录对应,然后 root /manyidea/www/svnweb/hddfront; 去除 dist 即可。
#重定向后台目录
location /dist/ {
root /manyidea/www/svnweb/hddfront;
location ~ ^/dist/.*\.(gif|jpg|jpeg|png|bmp|swf|flv)?$ {
root /manyidea/www/svnweb/hddfront;
expires 30d;
}
location ~ ^/dist/.*\.(js|css)?$ {
root /manyidea/www/svnweb/hddfront;
expires 1h;
}
}
解释:alias与root的区别
location /app {
root /var/www/html;
}
root 的路径为 /var/www/html/app
location /app {
alias /var/www/html;
}
alias 的路径 /var/www/html
root 是全路径。拼接 location 和 root 设置的路径
alias 相当于重置路径,重置为 alias 设置的路径
参考:
文明上网理性发言!
非常之感谢,网上找了一晚上,这篇解决了