创建名为spring_mvc_ajax的新module,过程参考9.1节和9.5节

10.1、SpringMVC处理Ajax请求

10.1.1、页面请求示例

<input type="button" value="测试SpringMVC处理Ajax请求" onclick="testAjax()">

<script type="text/javascript">
function testAjax() {
// 实例化 XMLHttpRequest 对象
var xhr = new XMLHttpRequest() // 设置请求方式和请求路径
// 因为thymeleaf语法只能应用于html的属性,所以在js中的请求要包含上下文信息
xhr.open("post","/spring_mvc_ajax/test/ajax?id=1001") // 设置请求头
// 一般 get 不需要设置,而 post 必须设置请求头
// 必须写在在open()和send()之间
xhr.setRequestHeader("Content-Type", "application/json") // 发送请求
// JSON.stringify() 是用来将合法的JSON数据字符串化的
xhr.send( JSON.stringify( {"username":"admin","password":123} ) ) // 设置 XMLHttpRequest 对象状态变化事件的处理函数
xhr.onreadystatechange = function () {
// readyState的值为4时,表示已获取到服务器的响应
if (xhr.readyState == 4){
// 在浏览器控制台输出服务器响应的内容
console.log(xhr.responseText)
}
}
}
</script>

10.1.2、控制器方法示例

    @RequestMapping("/test/ajax")
public void testAajx(Integer id , HttpServletResponse response) throws IOException {
// 通过形参获取 url 中的请求参数
System.out.println("id:"+id);
// 通过 HttpServletResponse 对象为 Ajax 请求响应(字符串)数据
response.getWriter().write("hello,ajax");
}

10.1.3、测试效果

10.2、@RequestBody注解的基础示例

10.2.1、作用

@RequestBody 注解用于将请求体中的内容和控制器方法中的形参进行绑定

10.2.2、控制器方法示例

页面请求示例,见10.1.1节

    @RequestMapping("/test/ajax")
public void testAajx(Integer id ,@RequestBody String requestBody ,HttpServletResponse response) throws IOException {
// 通过形参获取 url 中的请求参数
System.out.println("id:"+id); // 通过 @RequestBody 注解后的形参,获取请求体中的内容
System.out.println("requestBody:"+requestBody); // 通过 HttpServletResponse 对象为 Ajax 请求响应(字符串)数据
response.getWriter().write("hello,ajax");
}

10.2.3、测试效果

10.3、@RequestBody注解的进阶示例

10.3.1、前提条件一(引入jackson依赖)

        <!--jackson-->
<dependency>
<groupId>com.fasterxml.jackson.core</groupId>
<artifactId>jackson-databind</artifactId>
<version>2.12.1</version>
</dependency>

10.3.2、前提条件二(开启mvc的注解驱动)

mvc的注解驱动,在配置视图控制器和默认的servlet处理器的时候,已经开启;其重要性不言而喻

    <!--开启mvc的注解驱动-->
<mvc:annotation-driven></mvc:annotation-driven>

10.3.3、前提条件三(一个匹配json格式的Java类型)

匹配json格式的Java类型,一般是自定义实体类或map类型

package online.liaojy.pojo;

import java.io.Serializable;

/**
* @author liaojy
* @date 2023/10/30 - 0:02
*/
public class User implements Serializable { private Integer id; private String username; private String password; private Integer age; private String gender; public User() {
} public User(Integer id, String username, String password, Integer age, String gender) {
this.id = id;
this.username = username;
this.password = password;
this.age = age;
this.gender = gender;
} public Integer getId() {
return id;
} public void setId(Integer id) {
this.id = id;
} public String getUsername() {
return username;
} public void setUsername(String username) {
this.username = username;
} public String getPassword() {
return password;
} public void setPassword(String password) {
this.password = password;
} public Integer getAge() {
return age;
} public void setAge(Integer age) {
this.age = age;
} public String getGender() {
return gender;
} public void setGender(String gender) {
this.gender = gender;
} @Override
public String toString() {
return "User{" +
"id=" + id +
", username='" + username + '\'' +
", password='" + password + '\'' +
", age=" + age +
", gender='" + gender + '\'' +
'}';
}
}

10.3.4、页面请求示例

<input type="button" value="测试使用@RequestBody注解处理json格式的请求参数" onclick="testRequestBody()">

<script type="text/javascript">
function testRequestBody() {
// 实例化 XMLHttpRequest 对象
var xhr = new XMLHttpRequest() // 设置请求方式和请求路径
// 因为thymeleaf语法只能应用于html的属性,所以在js中的请求要包含上下文信息
xhr.open("post","/spring_mvc_ajax/test/RequestBody/json") // 设置请求头
// 一般 get 不需要设置,而 post 必须设置请求头
// 必须写在在open()和send()之间
xhr.setRequestHeader("Content-Type", "application/json") // 发送请求
// JSON.stringify() 是用来将合法的JSON数据字符串化的
xhr.send( JSON.stringify( {"username":"admin","password":"123","age":18,"gender":"男"} ) ) // 设置 XMLHttpRequest 对象状态变化事件的处理函数
xhr.onreadystatechange = function () {
// readyState的值为4时,表示已获取到服务器的响应
if (xhr.readyState == 4){
// 在浏览器控制台输出服务器响应的内容
console.log(xhr.responseText)
}
}
}
</script>

10.3.5、控制器方法示例(自定义实体类)

    // 通过 @RequestBody 注解形参,将json格式的请求参数转换为Java对象(自定义实体类)
@RequestMapping("/test/RequestBody/json")
public void testRequestBody(@RequestBody User user,HttpServletResponse response) throws IOException {
System.out.println("user:"+user);
response.getWriter().write("hello,RequestBody");
}

10.3.6、测试效果(自定义实体类)

因为json格式的请求参数中,没有包含id的键值对,所以转换后的Java实体类对象的id值为null

10.3.7、控制器方法示例(map集合)

    // 通过 @RequestBody 注解形参,将json格式的请求参数转换为Java对象(map集合)
@RequestMapping("/test/RequestBody/json")
public void testRequestBody(@RequestBody Map<String,Object> map, HttpServletResponse response) throws IOException {
System.out.println("map:"+map);
response.getWriter().write("hello,RequestBody");
}

10.3.8、测试效果(map集合)

10.4、@ResponseBody注解的基础示例

10.4.1、作用

@ResponseBody 注解用于将控制器方法的返回值,作为响应报文的响应体,响应到浏览器

10.4.2、页面请求示例

<a th:href="@{/test/ResponseBody}">测试通过@ResponseBody注解响应浏览器数据</a>

10.4.3、控制器方法示例(没使用@ResponseBody注解)

    @RequestMapping("/test/ResponseBody")
public String testResponseBody(){
return "success";
}

10.4.4、测试效果(没使用@ResponseBody注解)

没使用@ResponseBody注解时,return "success"响应的是success逻辑视图所对应的页面

10.4.5、控制器方法示例(有使用@ResponseBody注解)

    @RequestMapping("/test/ResponseBody")
@ResponseBody
public String testResponseBody(){
return "success";
}

10.4.6、测试效果(有使用@ResponseBody注解)

有使用@ResponseBody注解时,return "success"响应的是success字符串

10.5、@ResponseBody注解的进阶示例

10.5.1、前提条件

  • 引入jackson依赖,参考10.3.1节

  • 开启mvc的注解驱动,参考10.3.2节

  • 一个匹配json格式的Java类型,参考10.3.3节

10.5.2、页面请求示例

<input type="button" value="测试使用@ResponseBody注解响应浏览器json格式的数据" onclick="testResponseBody()">

<script type="text/javascript">
function testResponseBody() {
// 实例化 XMLHttpRequest 对象
var xhr = new XMLHttpRequest() // 设置请求方式和请求路径
// 因为thymeleaf语法只能应用于html的属性,所以在js中的请求要包含上下文信息
xhr.open("get","/spring_mvc_ajax/test/ResponseBody/json") // 设置请求头
// 一般 get 不需要设置,而 post 必须设置请求头 // 发送请求
xhr.send() // 设置 XMLHttpRequest 对象状态变化事件的处理函数
xhr.onreadystatechange = function () {
// readyState的值为4时,表示已获取到服务器的响应
if (xhr.readyState == 4){
// 在浏览器控制台输出服务器响应的内容
// JSON.parse()用来将JSON字符串,解析成字符串描述的JavaScript值或对象
console.log(JSON.parse(xhr.responseText))
}
}
}
</script>

10.5.3、Java对象与Json数据的转换关系

Java对象 Json数据
实体类 Json对象
map集合 Json对象
list集合 Json数组

10.5.4、控制器方法示例(实体类)

使用@ResponseBody注解,可以取代将Java对象通过第三方类库转换为Json字符串的繁琐过程

    @RequestMapping("/test/ResponseBody/json")
@ResponseBody
public User testResponseBodyjson(){
User user = new User(1001, "admin", "123456", 28, "男");
return user;
}

10.5.5、测试效果(实体类)

10.5.6、控制器方法示例(map集合)

    @RequestMapping("/test/ResponseBody/json")
@ResponseBody
public Map<String,Object> testResponseBodyjson(){
User user1 = new User(1001, "admin1", "123456", 28, "男");
User user2 = new User(1002, "admin2", "123456", 28, "男");
User user3 = new User(1003, "admin3", "123456", 28, "男");
Map<String, Object> map = new HashMap<String, Object>();
map.put("1001",user1);
map.put("1002",user2);
map.put("1003",user3);
return map;
}

10.5.7、测试效果(map集合)

10.5.8、控制器方法示例(list集合)

    @RequestMapping("/test/ResponseBody/json")
@ResponseBody
public List<User> testResponseBodyjson(){
User user1 = new User(1001, "admin1", "123456", 28, "男");
User user2 = new User(1002, "admin2", "123456", 28, "男");
User user3 = new User(1003, "admin3", "123456", 28, "男");
LinkedList<User> users = new LinkedList<User>();
users.add(user1);
users.add(user2);
users.add(user3);
return users;
}

10.5.9、测试效果(list集合)

与map集合转换后的json相比,list集合转换后的json外面用的是中括号(数组的符号),而且还有长度

![image](https://img2023.cnblogs.com/blog/2052479/202311/2052479-20231101173920863-1481359634.png

10.6、@RestController注解

  • @RestController 注解是springMVC提供的一个复合注解;

  • 其标识的位置是在类上面;

  • 其效果相当于为类添加了 @Controller 注解,并且为其中的所有方法都添加了 @ResponseBody 注解

@Controller
public class TestAjaxController { @RequestMapping("/test/ResponseBody")
@ResponseBody
public String testResponseBody(){
return "success";
} @RequestMapping("/test/ResponseBody/json")
@ResponseBody
public User testResponseBodyjson(){
User user = new User(1001, "admin", "123456", 28, "男");
return user;
} }
@RestController
public class TestAjaxController { @RequestMapping("/test/ResponseBody")
public String testResponseBody(){
return "success";
} @RequestMapping("/test/ResponseBody/json")
public User testResponseBodyjson(){
User user = new User(1001, "admin", "123456", 28, "男");
return user;
} }

10、SpringMVC之处理Ajax请求的更多相关文章

  1. springmvc框架下ajax请求传参数中文乱码解决

    springmvc框架下jsp界面通过ajax请求后台数据,传递中文参数到后台显示乱码 解决方法:js代码 运用encodeURI处理两次 /* *掩码处理 */ function maskWord( ...

  2. springmvc 前端 发ajax请求的几种方式

    一.传json单值或对象 1.前端 var data = {'id':id,'name':name}; $.ajax({ type:"POST", url:"user/s ...

  3. SpringMVC经典系列-13使用SpringMVC处理Ajax请求---【LinusZhu】

    注意:此文章是个人原创,希望有转载须要的朋友们标明文章出处,假设各位朋友们认为写的还好,就给个赞哈,你的鼓舞是我创作的最大动力,LinusZhu在此表示十分感谢,当然文章中如有纰漏,请联系linusz ...

  4. SpringMVC下Ajax请求的方法,@Responsebody如果返回的是布尔值,ajax不会接到任何回传数据

    SpringMVC框架下,如果用ajax向后台请求得方法如果使用@Responsebody返回布尔值的话,ajax得不到任何的回传数据. 但是如果返回String类型,就是正常的. 测试了下代码写得没 ...

  5. springmvc处理ajax请求

    1.controller将数据封装成json格式返回页面 @RequestMapping("/dataList") public void datalist(CsoftCunsto ...

  6. SpringMVC处理ajax请求的注意事项

    .首先要知道ajax请求的核心是JavaScrip对象和XmlHttpRequest,而浏览器请求的核心是浏览器 ajax请求 浏览器请求 场景一:使用ajax获取session中的user 从上图可 ...

  7. legend2---开发日志10(ajax请求的方法是否同样会执行base控制器里面的方法)

    legend2---开发日志10(ajax请求的方法是否同样会执行base控制器里面的方法) 一.总结 一句话总结:会执行的,所以写base控制器里面的方法要注意,base控制器里面的方法要以查数据为 ...

  8. springmvc接受及响应ajax请求。 以及@RequestBody 和@ResponseBody注解的使用

    1.发送ajax请求 $.ajax({ url:"user/testAjax", contentType:"application/json;charset=UTF-8& ...

  9. SpringMVC处理ajax请求的跨域问题和注意事项

    .首先要知道ajax请求的核心是JavaScrip对象和XmlHttpRequest,而浏览器请求的核心是浏览器我的个人博客(基于SSM,Redis,Tomcat集群的后台架构) github:htt ...

  10. SpringMVC中使用Ajax POST请求以json格式传递参数服务端通过request.getParameter("name")无法获取参数值问题分析

    SpringMVC中使用Ajax POST请求以json格式传递参数服务端通过request.getParameter("name")无法获取参数值问题分析 一:问题demo展示 ...

随机推荐

  1. Redis数据存储和读写

    今天工作群里,有小伙伴问了一个问题,从Redis获取的数据,一会是0,一会是OK. 这引起了我们对Redis数据存储和读写的疑问. 以下是整理的一些技术研究内容. 在 Redis 中,所有的数据存储都 ...

  2. Qt内存回收机制

    参考视频:https://www.bilibili.com/video/BV1XW411x7NU?p=16 Qt中内存的回收是自己完成的,实验中,我们自定义一个按钮,通过重写析构函数来观察现象. 新建 ...

  3. Qt初始化代码基本说明

    参考视频:黑马程序员https://www.bilibili.com/video/BV1XW411x7NU?p=4 1  工程基本介绍 按照这个基本步骤(https://www.cnblogs.com ...

  4. k8s网络问题以及容器跨宿主机通信原理

    [0]资源配置文件 [root@mcwk8s03 mcwtest]# ls mcwdeploy.yaml [root@mcwk8s03 mcwtest]# cat mcwdeploy.yaml api ...

  5. Win10下载纯净版ISO镜像

    进入windows官网下载页面 1.F12 进入开发者模式->选择浏览模式为手机->机型设置为Ipad Air ->刷新页面->下载选项出现 下图第二步选择完成后,需要刷新一下 ...

  6. Jupyter QtConsole 配置,2023 年了你还在使用 QtConsole 吗?

    目录 Jupyter QtConsole 配置,2023 年了你还在使用 QtConsole 吗? Jupyter QtConsole 的安装 设置字体 启动时自动加载需要的库包 更新:2023 年 ...

  7. ARM Cortex-A系列处理器性能分类比较

    在如今这个电子产品泛滥的年代,仅仅靠品牌或是外观已经不足以辨别产品的优劣,其内置的处理器自然也就成为了分辨产品是否高端的标准之一.那么我们今天就不妨好好了解一下近几年来电子产品中较为主流的RAM处理器 ...

  8. Oracle自动化编译无效对象

    问题描述:使用存储过程的方式对oracle数据库的无效对象,如视图或者同义词进行定期的编译,让他变成一个有效的对象,加上定时任务可以实现自动化的处理.同时在数据库内部创建一个记录表,用来记录被编译过的 ...

  9. 张高兴的 MicroPython 入门指南:(一)环境配置、Blink、部署

    目录 什么是 MicroPython 环境配置 硬件部分 软件部分 Hello World! Blink Pico 的引脚 常见电子元件 面包板 跳线 开关 发光二极管 电阻 使你的 Pico 闪烁 ...

  10. 是什么导致了客户端TCP连不上服务器?

      这几年做了很多基于 GGTalk开源即时通讯系统 的定制开发项目,经常会碰到如下两个问题,分享出来,应该对大家会有所帮助: (1)定制开发完成后,在给客户部署GGTalk即时通讯服务端到正式的服务 ...