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实现字节字符转bcd编码

《Java实现字节字符转bcd编码》BCD是一种将十进制数字编码为二进制的表示方式,常用于数字显示和存储,本文将介绍如何在Java中实现字节字符转BCD码的过程,需要的小伙伴可以了解下... 目录前言BCD码是什么Java实现字节转bcd编码方法补充总结前言BCD码(Binary-Coded Decima

SpringBoot全局域名替换的实现

《SpringBoot全局域名替换的实现》本文主要介绍了SpringBoot全局域名替换的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一... 目录 项目结构⚙️ 配置文件application.yml️ 配置类AppProperties.Ja

Java使用Javassist动态生成HelloWorld类

《Java使用Javassist动态生成HelloWorld类》Javassist是一个非常强大的字节码操作和定义库,它允许开发者在运行时创建新的类或者修改现有的类,本文将简单介绍如何使用Javass... 目录1. Javassist简介2. 环境准备3. 动态生成HelloWorld类3.1 创建CtC

JavaScript中的高级调试方法全攻略指南

《JavaScript中的高级调试方法全攻略指南》什么是高级JavaScript调试技巧,它比console.log有何优势,如何使用断点调试定位问题,通过本文,我们将深入解答这些问题,带您从理论到实... 目录观点与案例结合观点1观点2观点3观点4观点5高级调试技巧详解实战案例断点调试:定位变量错误性能分

Java实现将HTML文件与字符串转换为图片

《Java实现将HTML文件与字符串转换为图片》在Java开发中,我们经常会遇到将HTML内容转换为图片的需求,本文小编就来和大家详细讲讲如何使用FreeSpire.DocforJava库来实现这一功... 目录前言核心实现:html 转图片完整代码场景 1:转换本地 HTML 文件为图片场景 2:转换 H

Java使用jar命令配置服务器端口的完整指南

《Java使用jar命令配置服务器端口的完整指南》本文将详细介绍如何使用java-jar命令启动应用,并重点讲解如何配置服务器端口,同时提供一个实用的Web工具来简化这一过程,希望对大家有所帮助... 目录1. Java Jar文件简介1.1 什么是Jar文件1.2 创建可执行Jar文件2. 使用java

SpringBoot实现不同接口指定上传文件大小的具体步骤

《SpringBoot实现不同接口指定上传文件大小的具体步骤》:本文主要介绍在SpringBoot中通过自定义注解、AOP拦截和配置文件实现不同接口上传文件大小限制的方法,强调需设置全局阈值远大于... 目录一  springboot实现不同接口指定文件大小1.1 思路说明1.2 工程启动说明二 具体实施2

Java实现在Word文档中添加文本水印和图片水印的操作指南

《Java实现在Word文档中添加文本水印和图片水印的操作指南》在当今数字时代,文档的自动化处理与安全防护变得尤为重要,无论是为了保护版权、推广品牌,还是为了在文档中加入特定的标识,为Word文档添加... 目录引言Spire.Doc for Java:高效Word文档处理的利器代码实战:使用Java为Wo

SpringBoot日志级别与日志分组详解

《SpringBoot日志级别与日志分组详解》文章介绍了日志级别(ALL至OFF)及其作用,说明SpringBoot默认日志级别为INFO,可通过application.properties调整全局或... 目录日志级别1、级别内容2、调整日志级别调整默认日志级别调整指定类的日志级别项目开发过程中,利用日志

Java中的抽象类与abstract 关键字使用详解

《Java中的抽象类与abstract关键字使用详解》:本文主要介绍Java中的抽象类与abstract关键字使用详解,本文通过实例代码给大家介绍的非常详细,感兴趣的朋友跟随小编一起看看吧... 目录一、抽象类的概念二、使用 abstract2.1 修饰类 => 抽象类2.2 修饰方法 => 抽象方法,没有