让Nginx支持if多重判断方法
示例一:
nginx不支持if else 多重判断,需要用另一种方法来解决如下例:
location /api/opertree/ {
proxy_next_upstream error timeout invalid_header;
proxy_pass_header server;
proxy_http_version 1.1;
proxy_set_header Connection "";
set $flag 0;
if ($request_uri ~* "/api/XXX/onenode") {
set $flag "${flag}1";
}
if ($request_uri ~* "(uid=[0-9]*[5-9]\&)|((uid=[0-9]*[5-9]$))") {
set $flag "${flag}2";
}
if ($request_uri ~* "uid=((XXXX|XXXX)&)|((XXXX3|XXX3)$)") {
set $flag "${flag}3";
}
if ($flag ~* "01(2|3)")
{
proxy_pass http://commendfe/api/XXXX/list?$args;
break;
}
proxy_pass http://opertree;
}
示例二:
①nginx if判断&&(并且)写法
set $allowphp '';
if ($request_method ~ ^(POST)$) {
set $allowphp p;
}
if ( $request_filename !~ \.php$) {
set $allowphp "${allowphp}c";
}
if ( $allowphp = pc) {
set $allowss false;
}
PS:上面代码的意思是 post 提交并且是php文件的把变量$allowss设置成false
②nginx if判断||(或)写法
set $allowss true;
if ($http_x_forwarded_for ~ " ?222\.186\.34\.41$") {
set $allowss false;
}
if ($http_x_forwarded_for ~ " ?180\.97\.106\.37$") {
set $allowss false;
}
PS:ip地址222.186.34.41或180.97.106.37的把变量$allowss设置成false.上面的代码我主要用来禁用ip用的,因为我用了cdn所以ip判断用的$http_x_forwarded_for
③结合上面两段代码,实现禁止ip访问,禁止用post访问非php的文件
set $allowss true;
set $allowphp '';
if ($request_method ~ ^(POST)$) {
set $allowphp p;
}
if ( $request_filename !~ \.php$) {
set $allowphp "${allowphp}c";
}
if ( $allowphp = pc) {
set $allowss false;
}
if ($http_x_forwarded_for ~ " ?222\.186\.34\.41$") {
set $allowss false;
}
if ($http_x_forwarded_for ~ " ?180\.97\.106\.37$") {
set $allowss false;
}
if ($allowss = false) {
return 403;
}
以上是云栖社区小编为您精心准备的的内容,在云栖社区的博客、问答、公众号、人物、课程等栏目也有的相关内容,欢迎继续使用右上角搜索按钮进行搜索文档 , 文件 , 变量 , 代码 配置 nginx if 判断url、nginx if else 判断、nginx if 判断 不等于、nginx if 多重判断、nginx if 判断get参数,以便于您获取更多的相关知识。