城市直播房产教育博客汽车
投稿投诉
汽车报价
买车新车
博客专栏
专题精品
教育留学
高考读书
房产家居
彩票视频
直播黑猫
投资微博
城市上海
政务旅游

自己能调通接口,别人调不通?

5月1日 程染筱投稿
  原创:打码日记(微信公众号ID:codelogs),欢迎分享,转载请保留出处。场景
  有时我们开发了一个api接口,自己调得好好的,接口文档也写好了,但别人调用时就是有问题,而当我们调试时,发现请求根本没进来或进来了却取不到调用参数,该怎么告知对方调用姿势哪不对呢?解决方法
  对于编码新手,一般会和对方撕扯一会,然后甚至去review对方的代码,这样也许能解决问题,但自己毕竟不熟悉别人系统的实现,耗费时间较长。
  另外api调用端可能因为封装方式不同或者加过一些拦截器,导致你看调用端的代码根本看不到什么问题,或者因为调用参数有一些不易分辨或不可见的特殊字符,让你无法察觉到这里有问题。
  其实这种问题,我们从网络层出发,对比自己正确调用时的数据包与对方错误调用时的数据包内容,以此来诊断问题所在更加高效,毕竟任何封装或拦截器的处理,最终都会反馈在底层的交互数据上。
  这里,我使用springmvc开发一个简单的接口,如下:RestControllerpublicclassTestController{RequestMapping(valuetest,producesMimeTypeUtils。TEXTPLAINVALUE)ResponseBodypublicStringtest(RequestParam(namename)Stringname){}}
  这个接口就是直接将name参数的值返回了,然后我使用curl模拟正确与错误的调用方式,如下:正确调用方式curlhttp:localhost:8081testdataurlencodenameabab错误调用方式curlhttp:localhost:8081testdatanameabab
  假设调用方的代码实现的逻辑类似上面错误的调用方式,传递name参数为ab,得到的却是ab,接下来我们来定位看看,错误的调用方法问题在哪?
  方法1:使用wireshark抓包软件
  打开wireshark,先后抓包两次正常的以及不正常的请求数据,拿到请求数据后通过文本差异对比工具来对比。如下为wireshark两次抓包结果,使用追踪流TCP,查看HTTP请求数据
  如下为正确的HTTP请求数据,其中红色为请求数据,蓝色为响应数据
  如下为错误的HTTP请求数据
  对比请求数据差异
  可以看出,一个请求name参数为a2Bb,一个请求name参数为ab,显然这是由于name参数值没有urlencode导致的。
  另外或许你会奇怪,为啥错误请求值为ab,为啥代码里面获取到的却是ab?原因是tomcat接收到请求参数后,会做一次urldecode,而号会被decode为空格,java的URLDecoder。decode(ab,UTF8)也是如此。
  方法2:使用socat命令
  在抓包工具无法使用的情况下,可以尝试socat命令,使用socat命令来中转请求,调用端将请求先发给socat,socat再把请求转给服务端,如下:使用socat中转请求socatvTCP4LISTEN:8080,bind0。0。0。0,reuseaddr,forkTCP4:localhost:8081调用端访问socat监听的8080端口正确调用方式curlhttp:localhost:8080testdataurlencodenameabab错误调用方式curlhttp:localhost:8080testdatanameabab
  再去看socat,会发现如下结果:
  其中socat添加v参数后,会自动将中转的数据流以明文显示出来,其中类似2020101113:05:03。536294length162from0to161之后的部分,就是请求数据,而类似2020101113:05:03。740585length116from0to115之后的部分,就是响应数据,同样的,你可以将两次请求数据复制到文本对比工具中去发现差异。
  有时这种调用差异是特殊字符导致的,比如空白字符、零宽字符,上面的方式可能看不出差异,这时你可以将v参数替换为x参数,来对比数据的十六进制,同样的wireshark也可以查看数据包的十六进制,相信你摸索一下也可以找到。举一反三
  此外,有些时候,我们写的代码去查询数据库时,查不到数据,但我们把SQL拿到数据库客户端工具中,却可以查到数据,这种问题极有可能是SQL被底层一些拦截器改写了,这时,我们也可以使用上面的方法来确认,这里仅仅介绍使用socat的方式,如下,使用socat中转数据库连接:1。中转数据库连接socatvTCP4LISTEN:3307,bind0。0。0。0,reuseaddr,forkTCP4:localhost:330621teedata。log2。然后我们代码中连接数据库的地方,将端口改成3307,然后执行我们的SQL查询3。查看真实发送给数据库的SQLcatdata。loggrepiselect
  结果如下:
  我相信到这一步,大概能发现SQL差异了,接下来就是找到底层修改SQL的代码在哪,以及如何处置了。总结
  遇到这种网络调用上的差异问题,多多考虑使用wireshark、socat、ncat之类的网络工具来处理,相信问题处理效率会大大增加。
投诉 评论 转载

自己能调通接口,别人调不通?原创:打码日记(微信公众号ID:codelogs),欢迎分享,转载请保留出处。场景有时我们开发了一个api接口,自己调得好好的,接口文档也写好了,但别人调用时就是有问题,……TFboys名存实亡,3小只单飞5年后,如今发展差距有多大?你还记得TFboys上次同框是什么时候吗?估计很多人都不记得了,我记得,他们上次同框还是在2016年,距今,已经过去好几年了。这些年,粉丝们无时无刻都在期待TFbo……今日的大寨大寨这个地方,从小就存在我的记忆里。那时候,农村的墙壁上到处写着农业学大寨的标语,对于年幼的我来说,并不十分清楚代表着什么。随着时代的变迁,年龄的增长,对那段历史也……首轮发挥亮眼,半决赛却突然哑火,半决赛这5位球员表现令人失望目前,本赛季的NBA季后赛已经进入到了半决赛对决的白热化阶段,四轮系列赛大比分都已经打成了2:1,究竟胜负如何依然难以捉摸。而在首轮,包括吉米巴特勒、杰森塔图姆等球星,都打出了……手脚发麻也是病?1个方子,简单5味中药,补气又温阳,不妨了解手脚发麻,相信很多人都遇到过。长时间保持一个姿势,血流不流畅,从而导致手脚发麻。这种症状是比较正常的,但是日常生活中,感觉自己的手脚发麻的状态维持时间比较长。哪怕是换个姿……轻度抑郁症的人,可能常把6句口头禅挂在嘴边,希望你没说过夏方养生指南说到抑郁症,这也是生活当中最常见的一种心理疾病,以连续且长期的心情低落为主要临床特征,也是现代人心理疾病最常见的类型。尤其是随着现在生活节奏加快,工作生……春季的十渡竞如此荒凉正值北京残奥开幕和两会2022开始,公司部门打算做一次周末团建。搜罗了一圈,网上推荐十渡景区不错,但目前还不是旅游季应该人不会太多。抱着试试看看的态度公司决定团建地点在十渡。……中日两国同时减持美债,十八国也集中抛出美债,818吨黄金运抵3月7日,国际油价逼近每桶130美元,因油价在通胀预期中占据了非常高的比例,这让华尔街担心1970年代的美国滞胀幽灵重现,更加深了对美联储鹰派立场的担忧,这在当前俄乌局势紧张下……38岁的佟丽娅粉嫩装扮,清纯靓丽似少女3月7日,38岁的佟丽娅在社交平台晒出一段视频,视频中,佟丽娅一身粉嫩服装,五官精致,露出纤细的锁骨,满满的青春少女气息!清纯靓丽的佟丽娅,短发更突显出她独特的气质,光彩……男人刮胡子也有讲究?提醒这3个时间段内,尽量不要刮胡子胡须是男人特有的体征,胡须生长速度的快慢,主要受男性睾丸和肾上腺素的分泌,雄性激素旺盛的男性胡须生长速度快,胡须浓密,富有个人魅力。夏方养生指南每个进入青春期的男性,唇边……圆脸当不了主角?赵丽颖曾被导演羞辱,如今被打脸了吧你长着一张大饼脸,你这一辈子都当不了主角,这句话出自于一个导演的嘴里,赵丽颖有一个演员梦,她很喜欢演戏,虽然没有系统地学过表演,但她热爱这个行业,于是通过自己的努力成为演艺圈的……人如何面对孤独,战胜孤独?名著老人与海中早已道出真相孤独,似乎是人类永恒的话题,却又是人类最不想提及的话题。正如《百年孤独》中所说:生命从来不曾离开过孤独而独立存在。或许,人类的本质就是孤独的。然而,孤独并不等同于寂寞,孤……
对新课标下的高中物理教学浅谈太阳辐射与气温的关系十大数据通信技术创新发布,加速赋能行业数字化转型一个处男谈自己的处女观秦赵长平之战齐王建到底该不该救援赵国吃晚饭时,坚持喝点白酒的人,身体最后都怎样呢?医生告诉你真相明星作假花样多,脸是假的,身材是假的,连唱歌演戏也是假的转三步法小时复制粘贴的工作几高层访谈百度CIO李莹知识管理,企业提效创新中被忽略的短板家用洗地机有必要买吗今天七夕青蛙刷爆了朋友圈这是个什么梗什么意思大冷门!张本智和又输了,垂头丧气很沮丧,国乒世界冠军03日本

友情链接:中准网聚热点快百科快传网快生活快软网快好知文好找