百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术分类 > 正文

Nginx的rewrite之if指令(nginx if语句)

ztj100 2025-03-26 19:19 45 浏览 0 评论

if指令

该指令用来支持条件判断,并根据条件判断结果选择不同的Nginx配置。

语法 if (condition){...},嵌入位置是在 server、location

if后面,必须要有一个空格

condition为判定条件,可以支持以下写法:

  1. 变量名。如果变量名对应的值为空或者是0,if都判断为false,其他条 件为true。

具体配置实例:

vim nginx.conf //打开配置

$username如果为为空,就会输出0,如果变量名对应的值为空或者是0,if都判断为false,其他条件为true,此刻下面的return 输出的是empty

检验语法,重新加载

访问IP之后,输出了param is empty了

现在将$username设置成"ROSE"如果不是空字符串了

检验语法,重载配置

现在输出了ROSE了

还可以将if后面添加$args参数,

因为?没有,当前获取的值夜没有,最后返回了一个error

如果还有值,最终就返回了success

  1. 变量名。如果变量名对应的值为空或者是0,if都判断为false,其他条 件为true。
 if ($param){
 }

2. 使用"="和"!="比较变量和字符串是否相等,满足条件为true,不满 足为false

这里可以设置,如果是POST请求,就可以直接返回一个错误码

if ($request_method = POST){
 return 405;
 }

具体写法

第一次请求发送是GET请求

cmd简单访问请求的写法

curl -X POST http://xxx.xxx.xxx.xx:8081/testif

3. 使用正则表达式对变量进行匹配,匹配成功返回true,否则返回 false。变量与正则表达式之间

使用"~","~*","!~","!~*"来连接。

"~"代表匹配正则表达式过程中区分大小写,

"~*"代表匹配正则表达式过程中不区分大小写

"!~"和"!~*"刚好和上面取相反值,如果匹配上返回false,匹配不上返 回true

$http_user_agent存储的是客户端具体的版本信息,它所存储的是user_agent所需的值,在user_agent中所存储的是Safari的意思

具体检验写法:~ Safari

因为最后包含Safari的值,最终显示了Chrome

做一个检验大小写的配置 ~safari的写法

因为~区分了大小写,走了return系列

如果写了~*就能够匹配了

现在就看到了,已经满足了Chrome的配置条件了

4. 判断请求的文件是否存在使用"-f"和"!-f",

当使用"-f"时,如果请求的文件存在返回true,不存在返回false。
当使用"!f"时,如果请求文件不存在,但该文件所在目录存在返回
true,文件和目录都不存在返回false,如果文件存在返回false

5、用户请求在访问一个根本不存在的路径的时候,出现了404的问题,这种写法不太好看,如果想要编写一些提示信息使用"-f"和"!-f"进行判断

资源不存在的提示信息

访问了没有资源的页面显示的设置


5、判断请求的目录是否存在使用"-d"和"!-d", 
当使用"-d"时,如果请求的目录存在,if返回true,如果目录不存在 则返回false
当使用"!-d"时,如果请求的目录不存在但该目录的上级目录存在则返 回true,
该目录和它上级目录都不存在则返回false,如果请求目录存 在也返回false. 6. 判断请求的目录或者文件是否存在使用"-e"和"!-e" 
当使用"-e",如果请求的目录或者文件存在时,if返回true,否则返回 false. 当使用"!-e",如果请求的文件和文件所在路径上的目录都不存在返回 true,否则返回false 
7. 判断请求的文件是否可执行使用"-x"和"!-x" 当使用"-x",如果请求的文件可执行,if返回true,否则返回false 
当使用"!-x",如果请求文件不可执行,返回true,否则返回false

相关推荐

其实TensorFlow真的很水无非就这30篇熬夜练

好的!以下是TensorFlow需要掌握的核心内容,用列表形式呈现,简洁清晰(含表情符号,<300字):1.基础概念与环境TensorFlow架构(计算图、会话->EagerE...

交叉验证和超参数调整:如何优化你的机器学习模型

准确预测Fitbit的睡眠得分在本文的前两部分中,我获取了Fitbit的睡眠数据并对其进行预处理,将这些数据分为训练集、验证集和测试集,除此之外,我还训练了三种不同的机器学习模型并比较了它们的性能。在...

机器学习交叉验证全指南:原理、类型与实战技巧

机器学习模型常常需要大量数据,但它们如何与实时新数据协同工作也同样关键。交叉验证是一种通过将数据集分成若干部分、在部分数据上训练模型、在其余数据上测试模型的方法,用来检验模型的表现。这有助于发现过拟合...

深度学习中的类别激活热图可视化

作者:ValentinaAlto编译:ronghuaiyang导读使用Keras实现图像分类中的激活热图的可视化,帮助更有针对性...

超强,必会的机器学习评估指标

大侠幸会,在下全网同名[算法金]0基础转AI上岸,多个算法赛Top[日更万日,让更多人享受智能乐趣]构建机器学习模型的关键步骤是检查其性能,这是通过使用验证指标来完成的。选择正确的验证指...

机器学习入门教程-第六课:监督学习与非监督学习

1.回顾与引入上节课我们谈到了机器学习的一些实战技巧,比如如何处理数据、选择模型以及调整参数。今天,我们将更深入地探讨机器学习的两大类:监督学习和非监督学习。2.监督学习监督学习就像是有老师的教学...

Python教程(三十八):机器学习基础

...

Python 模型部署不用愁!容器化实战,5 分钟搞定环境配置

你是不是也遇到过这种糟心事:花了好几天训练出的Python模型,在自己电脑上跑得顺顺当当,一放到服务器就各种报错。要么是Python版本不对,要么是依赖库冲突,折腾半天还是用不了。别再喊“我...

超全面讲透一个算法模型,高斯核!!

...

神经网络与传统统计方法的简单对比

传统的统计方法如...

AI 基础知识从0.1到0.2——用“房价预测”入门机器学习全流程

...

自回归滞后模型进行多变量时间序列预测

下图显示了关于不同类型葡萄酒销量的月度多元时间序列。每种葡萄酒类型都是时间序列中的一个变量。假设要预测其中一个变量。比如,sparklingwine。如何建立一个模型来进行预测呢?一种常见的方...

苹果AI策略:慢哲学——科技行业的“长期主义”试金石

苹果AI策略的深度原创分析,结合技术伦理、商业逻辑与行业博弈,揭示其“慢哲学”背后的战略智慧:一、反常之举:AI狂潮中的“逆行者”当科技巨头深陷AI军备竞赛,苹果的克制显得格格不入:功能延期:App...

时间序列预测全攻略,6大模型代码实操

如果你对数据分析感兴趣,希望学习更多的方法论,希望听听经验分享,欢迎移步宝藏公众号...

AI 基础知识从 0.4 到 0.5—— 计算机视觉之光 CNN

...

取消回复欢迎 发表评论: