nginx if判断_Nginx重写规则(2)

需求:研发提出了一些路由跳跃的要求。
解决问题:在特殊情况下,如果业务和研发无法快速处理,则需要运维快速跳转来解决临时问题并避免出现较大的漏洞。

b141a50ef40f3ae4b9f6dfdc7e9a5f8e.png

Nginx重写规则

案例一:
临时将请求路径/colorv1/getcolorv1 的请求转发到 v2,且带着问号后面的参数 :
location ~ ^/(.)/(.)/colorv1/getcolorv1$ {
proxy_pass http://category-color-api/$1/$2/colorv2/getcolorv2?$args;
}
案例二:
任意开头和结尾的uri,重定向至"http://test.jenkins.com/jenkins"
location / {
rewrite ^/(.*)$ http://test.jenkins.com/jenkins;
}
location /jenkins {
proxy_pass http://127.0.0.1:8080/jenkins;
proxy_set_header Host $host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded_For $proxy_add_x_forwarded_for;
}
案例三
如果访问的URL以.sh .bash 结尾,返回状态码403
location ~ .*.(sh|bash)?$ {
return 403;
}
案例四
nginx 多判断条件语句如何实现? 比如,同时满足2个条件的请求,才转发。
nginx的配置中不支持if条件的逻辑中包含&& 或 || 的运算 ,而且不支持if的嵌套语法;
否则会报错误:nginx: [emerg] invalid condition; 对此情况我们可以用变量的方式来实现。
如: 请求到/color 的访问,请求方法是post,且refer 为abc.com;返回200:且显示内容{"code": 1, "msg": "发布成功"}, 其他不满足这两个条件的请求,转发到gateway;
location ~ /color$ {
set $post 0; ##定义变量
if ($request_method ~* "POST") {
set $post "${post}1";
}
if ($http_referer ~* "abc.com") {
set $post "${post}2";
}
if ($post = "012") {
return 200 '{"code": 1, "msg": "发布成功"}';
}
proxy_pass http://$gateway/a-b-api$request_uri;
}
案例五
禁止Scrapy等工具和UA为空的抓取
if ($http_user_agent ~* (Scrapy|Curl|HttpClient|^$)) {
return 403;
}
附:nginx配置完成之后,curl常用验证方法
当我们做了一些条件的限制,在本地curl验证通过方可上线:
-H "referer:abc" // 设置referer
-A "okhttp/3.12.0" // 设置请求 http_user_agent
-X POST //请求方法post
-d ‘{}’ //请求参数
curl -H "referer:" -A "okhttp/3.12.0" -X POST -d '{"user": "admin", "passwd":"123456

78"}' http://test.abc.com/1/7.3/color?client=064bfc8ch577e5f6

以上是云网时代小编关于Nginx重写规则的分享,希望能对大家有所帮助,云网时代为大家提供专业的深圳服务器租用,深圳服务器托管,深圳主机租用,云服务器租用等服务器资源,更多详情欢迎访问云网时代官网(www.szicp.com)了解。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值