0
点赞
收藏
分享

微信扫一扫

【测试平台开发】二十、完成编辑页发送接口请求功能

基于 springboot+vue 的测试平台(练手项目)开发继续更新。

今天终于把已做的功能都重构完成了。

其中前端又做了个小调整,就是入参动态增删的控件,本来我是3个tab复用一个组件,后来不断发现一些问题,最后我决定还是分开写吧。

【测试平台开发】二十、完成编辑页发送接口请求功能_spring

今天另一个重点是重做了编辑页发送接口请求的后端功能。这个功能重构之前是有的,但是现在我觉得之前那些做兼容不够。

因为我最近在工作中接入飞书的一些开放API,发现存在一些接口的入参是组合来的,比如 post 请求中,既有查询参数,也有请求体。

于是我重新梳理一下,尽量支持了各种参数组合:

  • 不带任何参数
  • 只有 param 查询参数
  • 只有 rest 路径参数
  • 只有 body 参数
  • 同时 param + body
  • 同时 rest + body

请求方法的话,暂时还是先支持 get 与 post 这2种最常见的。最后,把各种判断情况分支都走了一遍,确认没啥问题。

【测试平台开发】二十、完成编辑页发送接口请求功能_spring_02

功能实现

接下来记录下功能的实现。思路很简单:

  • 一些必要参数的获取与处理
  • 不同请求方法的判断
  • 进一步判断不同的参数组合情况,来进行发送http接口的处理。

用的 http 客户端是​​hutool​​框架的,代码位置在项目的这里,93行往后。

【测试平台开发】二十、完成编辑页发送接口请求功能_把苹果咬哭的不规律日常_03

首先,主方法前面处理一些必要的入参信息,比如 method、header、以及获取表单里的参数。

【测试平台开发】二十、完成编辑页发送接口请求功能_功能实现_04

接下来进入到请求方法的判断,然后进一步判断目前前端提交过来的各种类型的参数情况,这里抽出去写了 2 个判空的方法。

【测试平台开发】二十、完成编辑页发送接口请求功能_把苹果咬哭的不规律日常_05

以 get 方法为例,现在我可以判断出实际提交来的参数都有谁。

【测试平台开发】二十、完成编辑页发送接口请求功能_客户端_06

判断出参数类型,就可以针对性处理了,这里最麻烦的就是 rest 路径参数的处理,我前端提交来的路径参数是用花括号包着的​​{name}​​,所以要对url重新处理一下。

【测试平台开发】二十、完成编辑页发送接口请求功能_把苹果咬哭的不规律日常_07

拼接完成后,就可以直接发起请求了。

这里要注意的是,在​​hutool​​​的 http 客户端中,我入参使用​​body()​​​的时候会把​​form()​​​的参数覆盖掉,所以在处理请求体参数组合的情况下,只能把查询参数或者路径参数,都处理在请求 url 上。比如,这里是为了处理​​param+body​​​的组合,手动把​​param​​参数拼接到 url 上。

【测试平台开发】二十、完成编辑页发送接口请求功能_客户端_08

其他就没什么特别的了,在 post 中我觉得没必要支持那么多种情况,所以只兼容了 3 种情况。

【测试平台开发】二十、完成编辑页发送接口请求功能_把苹果咬哭的不规律日常_09

目前只是一个功能实现的诉求,还缺少一些异常的处理,后续慢慢补上。接下来会继续新功能的开发,过程中也会带着改一些我记录下来的 bug 。


--不要用肉体的勤奋,去掩盖思考的懒惰--

举报

相关推荐

0 条评论