Nginx中break和last的区别

本文详细介绍了Nginx配置中`break`和`last`指令的区别。`break`指令在重写后停止匹配当前location块,而`last`则会使用重写后的地址再次匹配location。通过示例解释了它们在文件下载保护和接口地址改写等场景下的应用。了解这两个指令的正确使用有助于优化Nginx服务器的配置。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

先说区别

  • last,重写后的规则,会继续用重写后的值去匹配下面的location。
  • break,重写后的规则,不会去匹配下面的location。使用新的规则,直接发起一次http请求了。

Nginx 配置文件

server {
        listen 88;
        server_name _;
        location /break { # location 1
          rewrite ^/break/(.*)$ /bak/$1 break;
        }
        location /last {  # location 2
          rewrite ^/last/(.*)$  /bak/$1 last;
        }

        location /bak {  # location 3
          default_type text/html;
          return 200 $uri;
        }

}

访问 http://rumenz.com:88/break/one

命中location1,浏览器地址栏没有变,直接去找/nginx/html/bak/one文件,由于没有这个文件所以返回404。

浏览器

image-20210114152319867

Nginx错误(error.log)日志

/nginx/html/bak/one failed (2: No such file or directory)

break表示重写后停止不再匹配location块。

访问 http://rumenz.com:88/last/one

命中location2,浏览器地址栏没有变,重新匹配到location3
image-20210114152832329

last表示重写后跳到location块再次用重写后的地址匹配

breaklast的使用场景

break

文件下载,隐藏保护真实文件服务器。

location /down {
  rewrite ^/down/(.*)$ https://rumenz.com/file/$1 break;
}

last

接口地址改写,将https://rumenz.com/api/list改写成https://rumenz.com/newapi/list

location /api {
  rewrite ^/api/(.*)$ /newapi/$1 last;
}

location /newapi {
  default_type Application/json;
  return 200 '{"code":200,"msg":"ok","data":["JSON.IM","json格式化"]}';
}

关注微信公众号:【入门小站】,解锁更多知识点

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值