nginx try_files

在有次配置前端文件时发现用root配完路径后,网页首次访问成功,刷新后就404了,搜索发现可能是前端代码中路由节点的问题,这里可以用nginx的try_files解决;

传送nginx文档中的解答: http://nginx.org/en/docs/http/ngx_http_core_module.html#try_files

Syntax:    try_files file ... uri;
         try_files file ... =code;
Default:    —
Context:    server, location

关键点1:按指定的file顺序查找存在的文件,并使用第一个找到的文件进行请求处理

关键点2:查找路径是按照给定的root或alias为根路径来查找的

关键点3:如果给出的file都没有匹配到,则重新请求最后一个参数给定的uri,就是新的location匹配

关键点4:如果是格式2,如果最后一个参数是 = 404 ,若给出的file都没有匹配到,则最后返回404的响应码

举例:

location /images/ {
    root /opt/html/;  # root 会将 location 匹配的路径缀在 root 参数的后面
    # alias /opt/html/;  #alias 则是将 location 匹配的路径的目录部分,替换为 alias 的参数

    try_files $uri   $uri/  /images/default.gif; 
}

比如 请求 127.0.0.1/images/test.gif 会依次查找

  • 1 文件/opt/html/images/test.gif
  • 2 文件夹 /opt/html/images/test.gif/ 下的index文件
  • 3 请求 127.0.0.1/images/default.gif

其他注意事项

  1. try-files 如果不写上 $uri/,当直接访问一个目录路径时,并不会去匹配目录下的索引页
    即访问127.0.0.1/images/不会去访问127.0.0.1/images/index.html

参考链接

nginx location 配置中 try_files, alias, root, index 的使用场合
nginx配置选项try_files详解

添加新评论