简单捋捋@RequestParam 和 @RequestBody的使用
前端向后端传递参数,后端怎么去接收,就会想到 spring 的注解
之前的话,我一直用的是 RequestParam("userName") String userName 这种形式,讲道理不怎么用 RequestParam String userName
无意间该去看看这两个是有什么不同了.
- @RequestParam
- @RequestBody (以 json 数据的形式接收)
如果不写 @RequestParam(xxx) 注解的话,那么就前端可以有 可以没有对应的xxx名字都行
如果有xxx名,那么就会自动匹配;
如果没有,请求也能正确发送。
一、 @RequestParam
/**
* 用户登录
* @param userName
* @param password
* @return
*/
@RequestMapping(value = "login", method = RequestMethod.POST)
public String login(@RequestParam String userName,
@RequestParam String password){
public BaseResponse login(@RequestParam("user") String userName,
@RequestParam("psd") String password){
如果前端不传 userName 或者 password 参数名的参数就会报错
1. 用 @RequestParam 前端传过来的参数名默认为 userName 我们String后面起的参数名
如果前端不传 user 或者 psd 参数名的参数就会报错
2. 用 @RequestParam("user") @RequestParam("psd"), 给前端传递过来的参数指定参数名
错误信息
3. "message":"Required String parameter 'userName' is not present"
其实还有其他的形式
看下面
@RequestParam(value="user" required=false) 这个注解
可以通过 required = false 或者 true 来要求 @RequestParam配置的前端参数是否一定要传
required = false 表示不传的话,会给参数赋值为 null ,required = true 就是必须要有
注意:
如果@requestParam注解的参数是int类型,并且required=false,此时如果不传参数的话,会报错。原因是,required=false时,不传参数的话,会给参数赋值null,这样就会把null赋值给了int,因此会报错。
使用 Integer 包装类型的话还要需要注意空指针异常
二、@RequestBody
@RequestBody 以 字符串 的形式接收前端传过来的请求体中的 json 数据
@RequestMapping(value = "login", method = RequestMethod.POST)
public String login(@RequestBody String jsonStr){
@RequestBody 以 简单对象 接收前端传过来的 json 数据
@RequestMapping(value = "login", method = RequestMethod.POST)
public String login(@RequestBody User user){

@RequestBody以 复杂对象 接收前端传过来的 json 数据
@RequestMapping(value = "login", method = RequestMethod.POST)
public String login(@RequestBody Team team){

参考: 笔者JustryDeng
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。
相关文章
浅析Java中Map与HashMap,Hashtable,HashSet的区别
HashMap和Hashtable两个类都实现了Map接口,二者保存K-V对(key-value对);HashSet则实现了Set接口,性质类似于集合2013-09-09
SpringBoot整合mybatis-generator插件流程详细讲解
这篇文章主要介绍了SpringBoot整合mybatis-generator插件流程,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习吧2023-02-02
MyBatis中高级多表查询(ResultMap、association、collection)详解
文章主要介绍了MyBatis中高级多表查询的四种方式:ResultMap、association、collection以及自连接查询,通过定义接口的抽象方法、编写mapper.xml和测试类,详细展示了如何根据复杂数据结构进行数据的装配和查询,感兴趣的朋友一起看看吧2024-11-11
Spring+Mybatis+Mysql搭建分布式数据库访问框架的方法
这篇文章主要介绍了Spring+Mybatis+Mysql搭建分布式数据库访问框架的方法,非常不错,具有参考借鉴价值,需要的朋友可以参考下2018-03-03


最新评论