Springboot开发 -- @RequestBody 接收参数的实例

2024-05-15 09:28

本文主要是介绍Springboot开发 -- @RequestBody 接收参数的实例,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Spring MVC @RequestBody 实现前后端数据交互

以下是一个使用 jQuery 的 $.ajax 方法发送 POST 请求到后端,后端使用 Spring MVC 的 @RequestBody 注解接收 JSON 参数的示例。

一、前端代码实现

// 假设你已经有了要发送的密码数据  
var passwordData = {  oldPwd: 'oldPassword',  newPwd: 'newPassword'  
};  // 使用 $.ajax 发送 POST 请求  
$.ajax({  url: 'user/changePwd', // 后端接收请求的 URL  type: 'POST', // 请求类型  contentType: 'application/json; charset=utf-8', // 发送的数据类型  dataType: 'json', // 期望从服务器返回的数据类型  data: JSON.stringify(passwordData), // 将对象转换为 JSON 字符串  success: function(response) {  // 请求成功时的处理逻辑  if (response.status === 1) {  // 密码修改成功  alert('密码修改成功!请重新登录!');  // 这里可以添加重定向或登出逻辑  } else {  // 密码修改失败  alert('密码修改失败:' + response.msg);  // 这里可以添加错误处理逻辑  }  },  error: function(jqXHR, textStatus, errorThrown) {  // 请求失败时的处理逻辑  alert('发生错误:' + textStatus + ', ' + errorThrown);  }  
});

二、后端代码 (Spring MVC)

  • 在后端,我们使用Spring MVC来接收前端发送的POST请求。
  • 首先,我们定义一个DTO(Data Transfer Object)类来接收前端发送的JSON数据。
  • 然后,我们创建一个Controller类,并使用@RestController和@PostMapping注解来映射前端发送的POST请求。
  • 在请求处理方法中,我们使用@RequestBody注解来自动将前端发送的JSON数据转换为DTO对象。
  • 最后,我们编写处理逻辑,并返回一个包含状态码和消息的JSON响应给前端。
import org.springframework.web.bind.annotation.PostMapping;  
import org.springframework.web.bind.annotation.RequestBody;  
import org.springframework.web.bind.annotation.RestController;  // 假设的 DTO (Data Transfer Object) 类  
public class PasswordChangeDTO {  private String oldPwd;  private String newPwd;  // 必须要有 getter 和 setter 方法  // ... getter 和 setter 方法 ...  // toString 方法可以方便调试时查看对象内容  @Override  public String toString() {  return "PasswordChangeDTO{" +  "oldPwd='" + oldPwd + '\'' +  ", newPwd='" + newPwd + '\'' +  '}';  }  
}  @RestController  
public class UserController {  @PostMapping("/user/changePwd")  public Map<String, Object> changePassword(@RequestBody PasswordChangeDTO passwordChangeDTO) {  // 这里是密码修改的逻辑  // passwordChangeDTO 中包含了从前端发送过来的 oldPwd 和 newPwd  // 假设密码修改成功  Map<String, Object> result = new HashMap<>();  result.put("status", 1);  result.put("msg", "密码修改成功!");  // 如果密码修改失败,可以返回不同的状态码和消息  return result;  }  
}

三、contentType/dataType/data 参数使用总结

在这个例子中,前端使用 $.ajax 发送了一个包含 JSON 数据的 POST 请求到 /user/changePwd。后端使用 Spring MVC 的 @RestController 和 @PostMapping 注解来映射这个请求,并使用 @RequestBody 来自动将 JSON 数据转换为 PasswordChangeDTO 对象。后端处理完请求后,返回一个包含状态码和消息的 JSON 响应给前端。前端在 success 回调中处理这个响应。

在 Ajax 数据传输 JSON 格式数据 参数时,要修改 contentTypedataType 如下:

  • contentType: ‘application/json; charset=utf-8’, // 发送的数据类型
  • dataType: ‘json’, // 期望从服务器返回的数据类型
  • data: JSON.stringify(passwordData), // 将对象转换为 JSON 字符串

在jQuery的$.ajax请求中,contentType、dataType和data这三个参数扮演着不同的角色,用于定义请求的各个方面。以下是这三个参数在发送Ajax请求时的使用总结:

1. contentType

  • contentType参数用于设置发送到服务器的数据的MIME类型。这通常与data参数一起使用,特别是当你要发送JSON数据到服务器时。

  • 用途:告诉服务器请求体的内容类型,以便服务器能够正确地解析数据。

  • 常见值:

‘application/x-www-form-urlencoded;charset=UTF-8’:#这是默认的MIME类型,用于发送简单的表单数据。
‘application/json;charset=utf-8’:当你发送JSON数据到服务器时,应该使用这个MIME类型。

  • 示例:当发送JSON数据时,你需要设置contentType为’application/json; charset=utf-8’,并使用JSON.stringify()将JavaScript对象转换为JSON字符串。

2. dataType

  • dataType参数用于指定你期望从服务器返回的数据类型。这会影响jQuery如何处理响应数据。

  • 用途:告诉jQuery如何处理服务器返回的数据。

  • 常见值:

‘xml’:期望返回XML数据。
‘html’:期望返回HTML内容。
‘json’:期望返回JSON数据。
‘text’:期望返回纯文本。
‘script’:期望返回JavaScript代码,并会执行它。

  • 示例:如果你期望服务器返回JSON数据,你应该设置dataType为’json’。这样,jQuery会自动将响应体解析为JavaScript对象,并可以在success回调函数中直接使用它。

3. data

  • data参数用于发送要提交给服务器的数据。这可以是简单的键值对,也可以是复杂的JavaScript对象或数组。

  • 用途:定义要发送到服务器的数据。

  • 格式:

键值对:{ key1: ‘value1’, key2: ‘value2’ }
数组:[ ‘value1’, ‘value2’ ]

  • 当发送JSON数据时,需要使用JSON.stringify()将JavaScript对象转换为JSON字符串。
  • 示例:
    如果你要发送一个包含用户信息的对象到服务器,你可以这样做:data: { username: ‘JohnDoe’, email: ‘johndoe@example.com’ }。
    如果要发送JSON数据,则需要先转换为字符串:data: JSON.stringify({ username: ‘JohnDoe’, email: ‘johndoe@example.com’ }),并设置contentType为’application/json; charset=utf-8’。

4. 总结

  • contentType定义了发送到服务器的数据的MIME类型,特别是当发送JSON数据时。
  • dataType指定了期望从服务器返回的数据类型,并影响jQuery如何处理响应数据。
  • data包含了要发送到服务器的数据,可以是简单的键值对、数组或JSON字符串。

通过正确设置这些参数,你可以确保Ajax请求按照预期的方式发送和接收数据。

这篇关于Springboot开发 -- @RequestBody 接收参数的实例的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/991447

相关文章

Java中Map的五种遍历方式实现与对比

《Java中Map的五种遍历方式实现与对比》其实Map遍历藏着多种玩法,有的优雅简洁,有的性能拉满,今天咱们盘一盘这些进阶偏基础的遍历方式,告别重复又臃肿的代码,感兴趣的小伙伴可以了解下... 目录一、先搞懂:Map遍历的核心目标二、几种遍历方式的对比1. 传统EntrySet遍历(最通用)2. Lambd

Spring Boot 中 RestTemplate 的核心用法指南

《SpringBoot中RestTemplate的核心用法指南》本文详细介绍了RestTemplate的使用,包括基础用法、进阶配置技巧、实战案例以及最佳实践建议,通过一个腾讯地图路线规划的案... 目录一、环境准备二、基础用法全解析1. GET 请求的三种姿势2. POST 请求深度实践三、进阶配置技巧1

springboot+redis实现订单过期(超时取消)功能的方法详解

《springboot+redis实现订单过期(超时取消)功能的方法详解》在SpringBoot中使用Redis实现订单过期(超时取消)功能,有多种成熟方案,本文为大家整理了几个详细方法,文中的示例代... 目录一、Redis键过期回调方案(推荐)1. 配置Redis监听器2. 监听键过期事件3. Redi

Spring Boot 处理带文件表单的方式汇总

《SpringBoot处理带文件表单的方式汇总》本文详细介绍了六种处理文件上传的方式,包括@RequestParam、@RequestPart、@ModelAttribute、@ModelAttr... 目录方式 1:@RequestParam接收文件后端代码前端代码特点方式 2:@RequestPart接

SpringBoot整合Zuul全过程

《SpringBoot整合Zuul全过程》Zuul网关是微服务架构中的重要组件,具备统一入口、鉴权校验、动态路由等功能,它通过配置文件进行灵活的路由和过滤器设置,支持Hystrix进行容错处理,还提供... 目录Zuul网关的作用Zuul网关的应用1、网关访问方式2、网关依赖注入3、网关启动器4、网关全局变

SpringBoot全局异常拦截与自定义错误页面实现过程解读

《SpringBoot全局异常拦截与自定义错误页面实现过程解读》本文介绍了SpringBoot中全局异常拦截与自定义错误页面的实现方法,包括异常的分类、SpringBoot默认异常处理机制、全局异常拦... 目录一、引言二、Spring Boot异常处理基础2.1 异常的分类2.2 Spring Boot默

基于SpringBoot实现分布式锁的三种方法

《基于SpringBoot实现分布式锁的三种方法》这篇文章主要为大家详细介绍了基于SpringBoot实现分布式锁的三种方法,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录一、基于Redis原生命令实现分布式锁1. 基础版Redis分布式锁2. 可重入锁实现二、使用Redisso

SpringBoot的全局异常拦截实践过程

《SpringBoot的全局异常拦截实践过程》SpringBoot中使用@ControllerAdvice和@ExceptionHandler实现全局异常拦截,@RestControllerAdvic... 目录@RestControllerAdvice@ResponseStatus(...)@Except

Springboot配置文件相关语法及读取方式详解

《Springboot配置文件相关语法及读取方式详解》本文主要介绍了SpringBoot中的两种配置文件形式,即.properties文件和.yml/.yaml文件,详细讲解了这两种文件的语法和读取方... 目录配置文件的形式语法1、key-value形式2、数组形式读取方式1、通过@value注解2、通过

Java 接口定义变量的示例代码

《Java接口定义变量的示例代码》文章介绍了Java接口中的变量和方法,接口中的变量必须是publicstaticfinal的,用于定义常量,而方法默认是publicabstract的,必须由实现类... 在 Java 中,接口是一种抽象类型,用于定义类必须实现的方法。接口可以包含常量和方法,但不能包含实例