@RequestParam和 @ApiParam注解使用

这篇具有很好参考价值的文章主要介绍了@RequestParam和 @ApiParam注解使用。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

@RequestParam和 @ApiParam注解使用

新工作干了一段时间了,项目上使用之前没接触过的swagger,确实要方便许多,之前在上家实习的时候,项目上没有接口文档,后端和前端之间都是简单地在微信上发个接口要什么字段,英文名,中文解释。。。效率低,麻烦还容易搞错,现在只要后端顺手打上注释,项目启动,把ip和端口告诉前端,他直接就能看到接口文档,省了后端不少心。我目前用的最多的,也是直接影响到前端查看文档的注解,就是 @RequestParam@ApiParam,本人刚毕业的小菜鸡,欢迎大家发表自己的看法

1. @RequestParam和@ApiParam的常用属性

@RequestParam和@ApiParam所具有的属性在名字上高度重合,但意义和默认值却不相同,以下做出对比:

@RequestParam @ApiParam
属性名 默认值 解释 属性名 默认值 解释
value "" 入参的名称,就是前端传给后端的名字 value "" 相当于@RequestParam的name属性
name "" 对参数名的描述,就是入参的中文意思 name "" 相当于@RequestParam的value属性
required true 给入参添加限制条件,false说明前端可传可不传,true则必传,不传报错 required false 两者一样
defaultValue "\n\t\t\n\t\t\n\ue000\ue001\ue002\n\t\t\t\t\n" 给入参设置默认值,即使前端没有传这个参数,后端也能获取到这个参数,参数值就是defaultValue的属性值 defaultValue "" 两者一样

2. 两者搭配使用的一些具体写法

  • 项目组内最多的写法
public DataResult<ZonesEiaPlanPageInfoVO> detail(@RequestParam @ApiParam(name = "主键", value = "id") String id) {}

@RequestParam和 @ApiParam注解使用

这里名称和描述的位置反了
虽然前端肯定知道要传英文参数,但如果前端直接用文档调用接口,文档把中文当参数名传递给后台,那肯定得不到正确结果,报异常:Required String parameter ‘id’ is not present
这里发现并未显式设置required属性,@RequestParam的默认值是true,而@ApiParam的默认值是false,好像是@RequestParam说了算。
考虑到注解书写的先后顺序会不会有影响,自己颠倒两个注解的前后位置,又试了试,发现结果还是一样的

  • 也有人这样写
public DataResult<ZonesEiaPlanPageInfoVO> detail(@RequestParam @ApiParam(value = "主键") String id) {}

@RequestParam和 @ApiParam注解使用

文档显示没问题,接口调用也没有问题,但是并没有显示设置参数名称,这就要确保前端传递参数要和方法的形参名称保持一致

  • 还有人这样写
 public DataResult<ZonesEiaPlanPageInfoVO> detail(@RequestParam @ApiParam("id") String id) {}

@RequestParam和 @ApiParam注解使用

这样名称和描述就都是英文了,接口调用没问题,但文档可读性大大降低

  • 最后来说说我自己是怎么写的

非必传的参数

public DataResult<ZonesEiaPlanPageInfoVO> detail(@RequestParam(value= "id", required = false) @ApiParam("主键") String id) {}

@RequestParam和 @ApiParam注解使用

必传的参数

public DataResult<ZonesEiaPlanPageInfoVO> detail(@RequestParam("id") @ApiParam(value = "主键", required = true) String id) {}

@RequestParam和 @ApiParam注解使用

可以看出文档对于必传参数,做了加重和标识,所以说required属性最好带上,让前端一眼看出那些参数必须向后台传递,那些又是可有可无的参数
记住一句话:@RequestParam和@ApiParam两者,谁的required属性默认值与预想效果不一致,就需要显示声明required属性值
后来发现自己好笨啊,其实直接在@ApiParam里设置好name(字段名:英文)、value(字段描述:中文)和required三者的属性值就好了。
必传参数

public DataResult<ZonesEiaPlanPageInfoVO> detail(@RequestParam @ApiParam(name = "id", value = "主键", required = true) String id) {}

非必传参数(required属性默认就是false,可省略不写)文章来源地址https://www.toymoban.com/news/detail-432568.html

public DataResult<ZonesEiaPlanPageInfoVO> detail(@RequestParam @ApiParam(name = "id", value = "主键", required = false) String id) {}

到了这里,关于@RequestParam和 @ApiParam注解使用的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • PostMan、ApiFox等工具Post请求中@RequestParam和@RequestBody的混合使用如何传参

    方法签名 以ApiFox为例子 @RequestParam的Params的参数正常传参 @RequestBody的参数要以json的格式传输 同时Header中要指明 Content-Type=application/json 这样就OK了。 祝:工作顺利,永不加班,生活开心。

    2024年02月05日
    浏览(34)
  • @RequestParam和@RequestBody

    前言 在开发中我们往往会使用到post、get、delete等方法去请求数据,那么我们如何接到前端传过来的数据呢。不同数据类型又如何接收呢? 我们在使用 postman 的时候看到五花八门的请求方法,众多的传输数据方法。 我们都知道在springboot中使用@RequestParam和@RequestBody去接收数据

    2024年02月14日
    浏览(31)
  • @RequestParam @RequestBody @PathVariable用法详解

    三个注解都是在我们进行请求时对服务端参数进行封装的,那么具体三个注解的使用,什么情况下,什么条件下使用呢? @RequestParam接收的参数是来自于RequestHeader中,即请求头。 @RequestParam用来处理 Content-Type 为 application/x-www-form-urlencoded 编码的内容,Content-Type默认为该属性。

    2024年02月13日
    浏览(33)
  • Spring MVC的@RequestParam分析

    本篇文章涉及到一下相关问题 1.报错Required String parameter \\\'xx\\\' is not present 2.@RequestParam接收post请求参数报错 3.@RequestParam使用原理 4.springmvc使用@RequestParam一样的参数名,怎么接收不到。 5.axios发送post请求,springMVC接收不到数据问题 代码中是规定了请求方式 POST ,使用 @RequestPara

    2023年04月23日
    浏览(27)
  • Postman测试@RequestBody和@RequestParam参数案例

    Postman是一款强大的接口测试工具。 代码如下(示例): 个人感觉 flag 字段放到 StudentScore 对象中会比较方便处理; 回到顶部

    2024年02月15日
    浏览(32)
  • 详细分析Java中的@RequestParam和@RequestBody

    该知识点主要来源于SpringMVC:SpringMVC从入门到精通(全) 慢慢作为一名全栈,偶尔看项目使用 @RequestParam 或者 @RequestBody ,对此需要做一个深度的总结,防止混淆 @RequestParam 注解用于从HTTP请求中提取查询参数或表单参数。 其中一些常用的属性参数包括 name 、 defaultValue 和 r

    2024年04月26日
    浏览(31)
  • @RequestBody,@RequestParam,@RequestPart应用场景和区别

    使用此注解接收参数时,适用于请求体格式为 application/json,只能用 对象接收 支持application/json,也同样支持multipart/form-data请求 @RequestPart 这个注解用在 multipart/form-data 表单提交请求的方法上。 支持的请求方法的方式 MultipartFile ,属于Spring的 MultipartResolver 类。这个请求是通过

    2024年02月04日
    浏览(34)
  • 在SpringBoot中@PathVariable与@RequestParam的区别

    使用 @PathVariable 注解时,参数会从请求的路径中提取。在你的URL中,路径参数通常是通过 {} 包裹的形式出现,例如 /{getUserById}/123 . postman测试:http://localhost:8080/test/user/1 使用 @RequestParam 注解时,参数会从请求的查询参数中提取。在你的URL中,查询参数通常是通过 ? 后面的键值

    2024年02月19日
    浏览(26)
  • Java替换RequestBody和RequestParam参数的属性

    Java替换RequstBody和RequestParam参数的属性 近期由于接手的老项目中存在所有接口中新增一个加密串来给接口做一个加密效果(项目历史原因,不方便上Jwt授权这套),所以就研究了一下Http请求链路,发现可以通过 javax.servlet.Filter 去实现 首先通过继续 HttpServletRequestWrapper 来达到获

    2024年02月08日
    浏览(33)
  • Postman 的post请求@RequestParam参数,该如何写路径

     如上图springboot的项目,post请求,但是请求参数不是@RequestBody,而是@RequestParam,这时候,你的请求参数就要写在路径上,如下图  

    2024年02月05日
    浏览(47)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包