url中出现大括号的有趣问题
背景
线上又出现了一起问题
请求是: /easicar/v1/subCourses/{subCourseId}/comments/create
因为node服务的有bug,{subCourseId},没有用值覆盖它,在线上不正常返回400,在测试环境正常(虽然没赋值,后端也没用到subCourseId这个值)
原因还是因为上篇文章讲过的原因:http://arthur-zhang.github.io/2018/09/11/nginx-merge-slash/
实验结果如下
1. server 后面有内容的时候 (模拟线上情况) |
可以看到Nginx
这个坑货,在server
后面有内容的时候,会把url
解码、合并斜杆后的url
传给upstream
服务器,但是tomcat
会拒绝掉部分未经编码的他觉得不合法的字符。
无论发起方编码的多么好,都会有问题
解决办法有两种:
- 修改
Nginx
配置 - 修改
tomcat
配置Connector
中relaxedQueryChars
属性,使之支持{
这些特殊字符
那么哪些是http协议认为的合法的字符呢?
写了一段代码,经过一层Nginx
,转发到tomcat
,遍历了0-127的所有字符,以下字符是一定不被tomcat
允许的
" 0x22 |
看tomcat
源码也可以知道
if (IS_CONTROL[i] || i > 127 || |
具体可以参考:RFC 7230 和 RFC 3986
参考链接:
https://stackoverflow.com/questions/1547899/which-characters-make-a-url-invalid/13500078#13500078
细心的人可以发现,没有完全对应上,可以留做下一篇文章