详解Nginx如何根据swagger关键字屏蔽页面

 更新时间:2023年08月01日 09:47:26   作者:ACGkaka_  
这篇文章主要为大家详细介绍了Nginx 如何根据swagger关键字屏蔽页面的实现方案,文中有详细的解决方案,对我们的学习或工作有一定的帮助,需要的朋友可以参考下

一、知识回顾

1.什么是 location

Nginx 中通过根据 location 块的规则来将匹配到的 URL 请求进行一系列操作,最常见的就是进行代理。Nginx 中一个 Server 可以有多个 location 配置,当请求在与多个 location 匹配时,会根据一定的 location 匹配规则和优先级来确定具体将请求分发到哪个 location。

2.location 语法

# |指令|  |前缀|   |匹配的网站网址|  |匹配URI之后要执行的配置段|
location [=|^~|~|~*] /uri/ { ... }

3.location 的匹配规则

匹配规则说明
没有前缀普通匹配(遵循最大前缀匹配规则)。
=精确(严格)匹配。
~区分大小写的正则匹配。
~*不区分大小写的正则匹配。
^~匹配 URI 以某个常规字符串开头,^ 为正则表达式中的开头。
!~区分大小写不匹配的正则。
!~*不区分大小写不匹配的正则。
/通用匹配,任何请求都会匹配到。

由此我们可以根据是否按照正则匹配将 location 的匹配规则划分为两类:

  • 普通location: 包括 没有前缀=^~@ 四种。其中 @ 时用作服务内部的一种转发行为,很少用。
  • 正则location: 包括 ~~*!~!~* 四种。

4.优先级排序

具体的匹配顺序生效规则如下:

  • 普通 location 与正则 location 之间的匹配:选择出 “普通 location” 的最大前缀匹配结果后,还需要继续搜索正则 location。如果继续搜索的 “正则 location” 也有匹配上的,那么 “正则 location” 覆盖 “普通 location” 的最大前缀匹配。
  • 普通 location 之间:最大前缀匹配。
  • 正则 location 之间:按照正则 location 在配置文件中的物理顺序(编辑顺序)匹配,并且只要匹配到一条正则 location,就不再考虑后面的。
  • 以上 “普通 location” 指的是 没有前缀 和 @,= 和 ^~ 在匹配到结果后就不再需要继续匹配 “正则 location” 了(^ 表示 “非”,~ 表示 “正则”,字符意思是:不要继续匹配正则)。
    • = 和 ^~ 共同点:都可以阻止继续匹配 “正则 location”。
    • = 和 ^~ 不同点:^~ 依然遵守 “最大前缀” 匹配规则,然而 = 不是 “最大前缀”,而是必须是严格匹配(exact match)。

所有类型location存在时,优先级排序为:

=匹配 > ^~匹配(不是用正则,最大前缀匹配) > 正则匹配 > 没有前缀(最大前缀匹配) > 默认(/)

location / {} 和 location = / {} 的区别:

  • location / {} 遵守普通 location 的最大前缀匹配,由于任何 URI 都必然以 / 根开头,所以对于一个 URI,如果有更 specific 的匹配,那自然是选这个更 specific 的,如果没有,/ 一定能为这个 URI 点背(至少能匹配到 /)。也就是说,location / {} 有默认配置的意思,其他更 specific 的配置能 orverwrite 这个默认配置(这也是为什么我们总能看到 location / {} 这个配置的原因)。
  • location = / {} 遵守的是 “严格精确匹配 exact match”,也就是只能匹配 http://host:port/ 请求,同时会禁止继续搜索正则 location。因此如果我们只想对 “GET /” 请求配置作用指令,那么我们可以选 location = / {},这样能减少正则 location 的搜索,因此效率比 location / {} 高(注:前提是我们的目的仅仅只想对 “GET /” 起作用)。

二、如何根据关键字筛选请求

1.实现方案

可以利用以下四种匹配规则实现:

匹配规则说明
~区分大小写的正则匹配。
~*不区分大小写的正则匹配。
!~区分大小写不匹配的正则。
!~*不区分大小写不匹配的正则。

例如,我想根据 swagger 关键字进行筛选,将带有 swagger 的请求全部拦截,我们可以这么实现:

location ~* swagger {
    return 404;
}

2.测试结果

访问地址:http://localhost:8081/swagger-ui.html

整理完毕!

参考地址:

1.Nginx之location匹配规则,https://www.cnblogs.com/gaoyanbing/p/16915446.html

到此这篇关于详解Nginx如何根据swagger关键字屏蔽页面的文章就介绍到这了,更多相关Nginx swagger屏蔽页面内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • 树莓派如何搭建web服务器(nginx +php + mysql + vsftpd +phpmyadmin)

    树莓派如何搭建web服务器(nginx +php + mysql + vsftpd +phpmyadmin)

    本文介绍如何使用树莓派搭建Web服务器,包括安装Nginx、PHP、MySQL、ftp和phpMyAdmin,步骤详尽,涵盖不同架构的PHP安装,提供了配置MySQL远程访问和管理数据库的方法,是搭建个人Web服务器的实用指南
    2024-11-11
  • 深入理解Nginx中的sites-enabled目录

    深入理解Nginx中的sites-enabled目录

    Nginx是高性能的HTTP服务器和反向代理,其中sites-enabled目录对于配置管理非常关键,该目录存放已启用站点的符号链接,使得启用或禁用站点配置变得简单高效,下面就来介绍一下
    2024-09-09
  • nginx日志中添加请求的response日志(推荐)

    nginx日志中添加请求的response日志(推荐)

    这篇文章主要介绍了nginx日志中添加请求的response日志,非常不错,具有参考借鉴价值,需要的朋友可以参考下
    2018-05-05
  • nginx http 499错误码详解以及解决办法

    nginx http 499错误码详解以及解决办法

    HTTP状态码出现499错误有多种情况,499错误是什么?这篇文章主要给大家介绍了关于nginx http 499错误码以及解决办法的相关资料,文中介绍的非常详细,需要的朋友可以参考下
    2024-01-01
  • 制作能在nginx和IIS中使用的ssl证书

    制作能在nginx和IIS中使用的ssl证书

    现在的后端开发,动不动就是需要https,或者说是需要ssl证书,既然没有正版的证书,那么我们只能自己制作ssl的证书了。 证书的制作采用的是openssl工具,如果没有,可以自行安装下,因为笔者是在linux(ubuntu)下制作,所以一般是使用包管理工具(apt)安装好了的
    2021-06-06
  • Nginx为已安装nginx动态添加模块

    Nginx为已安装nginx动态添加模块

    本篇文章主要介绍了Nginx之为已安装nginx动态添加模块的方法,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-04-04
  • 解决Nginx无法启动 -10013: An attempt was made to access a socket in a way forbidden by its access permission的问题

    解决Nginx无法启动 -10013: An attempt was 

    这篇文章主要给大家介绍了解决用nginx -t 发成Nginx无法启动报错10013: An attempt was made to access a socket in a way forbidden by its access permissions的问题,需要的朋友可以参考下
    2023-11-11
  • windows下快速安装nginx并配置开机自启动的方法

    windows下快速安装nginx并配置开机自启动的方法

    这篇文章主要介绍了windows下快速安装nginx 并配置开机自启动的相关知识,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2021-05-05
  • Nginx中的用户认证配置及阻止用户使用代理访问的方法

    Nginx中的用户认证配置及阻止用户使用代理访问的方法

    这篇文章主要介绍了Nginx中的用户认证配置及阻止用户使用代理访问的方法,用户认证部分用到了自带的ngx_http_auth_basic_module模块,需要的朋友可以参考下
    2016-01-01
  • Nginx配置origin限制跨域请求的详细过程

    Nginx配置origin限制跨域请求的详细过程

    这篇文章主要介绍了Nginx配置origin限制跨域请求的相关知识,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2023-06-06

最新评论