首页 > 其他分享 >10、SpringMVC之处理Ajax请求

10、SpringMVC之处理Ajax请求

时间:2023-11-01 21:25:43浏览次数:29  
标签:10 请求 xhr SpringMVC ResponseBody Ajax User 注解 public

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

10.1、SpringMVC处理Ajax请求

10.1.1、页面请求示例

image

<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、控制器方法示例

image

    @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、测试效果

image

image

image

image

image

10.2、@RequestBody注解的基础示例

10.2.1、作用

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

10.2.2、控制器方法示例

页面请求示例,见10.1.1节

image

    @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、测试效果

image

image

image

10.3、@RequestBody注解的进阶示例

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

image

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

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

image

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

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

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

image

匹配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、页面请求示例

image

<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、控制器方法示例(自定义实体类)

image

    // 通过 @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、测试效果(自定义实体类)

image

image

image

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

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

image

    // 通过 @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集合)

image

image

image

10.4、@ResponseBody注解的基础示例

10.4.1、作用

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

10.4.2、页面请求示例

image

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

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

image

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

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

image

image

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

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

image

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

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

image

image

有使用@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、页面请求示例

image

<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、控制器方法示例(实体类)

image

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

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

10.5.5、测试效果(实体类)

image

image

image

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

image

    @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集合)

image

image

image

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

image

    @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集合)

image

image

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

![image](/i/l/?n=23&i=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,请求,xhr,SpringMVC,ResponseBody,Ajax,User,注解,public
From: https://www.cnblogs.com/Javaer1995/p/17792497.html

相关文章

  • 解题报告 P2572 [SCOI2010] 序列操作
    P2572[SCOI2010]序列操作线段树。首先对于一个区间,我们需要存储\(8\)个量来保证算出答案:\(1\)的个数,\(0\)的个数,最左边连续\(1/0\)个数,最右边连续\(1/0\)个数,区间内最长连续\(1/0\)个数。可以如下定义一个节点:structnode{ intcnt1,cnt0,ls1,ls0,rs1,rs0,ss1,s......
  • 20231030
    上午去搓了铁,用小锯子锯了一段钢柱,加工成了一个心形,总之就是很累,学到了这个技术,感觉我也可以去工地了,学什么编程,哈哈。下午上课Java测试,勉强过关,分数低是因为没有写完前端页面,前端功能没实现完。下午和同学确定了一个新的玩具的选题,最近又有事情做了。......
  • CF1039D You Are Given a Tree
    CF1039DYouAreGivenaTree更好的阅读体验一种神奇套路:对答案根分,根分的依据是链的长度和答案大致是一个成反比的关系。考虑确定了\(k\)怎么做。因为一个点只能在一条链里,所以dfs的时候如果能拼成一条链就一定会拼成一条链,不然就把贡献传给父亲继续尝试。对于\(k\)比......
  • 20231101构造题记录
    20231101构造题记录A.人生的经验可以对于每个长度为\(l-1\)的串建一个点,每个点有\(c\)个后继状态,也有\(c\)个入边,所以一定可以找到一个欧拉路因此答案为\(c^l+l-1\)即所有可能的串首尾相接拼起来的长度考虑用一个圈套圈求欧拉路,即每次拓展一个点,用栈维护,如果不能继......
  • CF GYM 104020 G
    link首先,因为\(w_i\le10^6\),有点大,所以我们想方设法把他变小一点。设一个快为\(w_i=k\timesx+r\)。其实,如果我们把他分为\(x\)个大小为\(k\)的块,然后一个大小为\(r\)的块是最优的。因为切成其他的大小的块,我们可以调整成这种切法,答案不是更劣。比如说,有934这三个......
  • AJAX-解决回调函数地狱问题
    一、同步代码和异步代码1.同步代码浏览器是按照我们书写代码的顺序一行一行地执行程序的。浏览器会等待代码的解析和工作,在上一行完成之后才会执行下一行。这也使得它成为一个同步程序。总结来说:逐行执行,需原地等待结果后,才继续向下执行2.异步代码异步编程技术使你的程序可以在一个......
  • app支付金额为100,但是前端却显示50,这种情况是怎么回事呢?该如何处理?
    app支付金额为100,但是前端却显示50,这种情况是怎么回事呢?该如何处理?1、可能是服务端没有正常响应返回数据导致的问题--前端发起请求到服务端后没有正常响应返回响应数据,导致回显金额跟实际支付金额不一致;2、可能是前端展示的问题--前端正常请求了,服务端也正常响应返回数据了,包括......
  • CF1025F Disjoint Triangles
    虽然我不懂计算几何,但是两个三角形互相进入,感觉很涩啊!——By【】考虑两个互不相交的三角形,寻找一个方式能够不重不漏地统计它们。容易发现两条不交的线段\(A_1A_2,B_1B_2\)之间,必然存在一条直线将\(A_1A_2,B_1B_2\)分在直线两端,且与\(A_1A_2,B_1B_2\)无交。证明的话,......
  • Linux【CPU100% 问题定位】
    一、场景     在我们项目部署上线的时候,我们是不是会经常去Linux服务器上查查服务器的CPU使用率,或者是运维经常会盯Linux的CPU使用率。如果CPU使用率一直100%,如何查找并解决问题?二、步骤    2.1、定位到进程        使用top和ps分析工具报告......
  • 20231101
    T1考虑先跑m遍KMP,记录下每个可以造成贡献的起点,再直接\(O(n^2)\)DP就可以了。思路比较好想,据说可以AC自动机做得分:没交上去......T2观察前50%的数据,发现O(nk)可以直接过。再考虑第四个子任务。所有颜色相同,那么其他的K-1种颜色都是连通图,通过边数判断一下是否是树即可。正解考虑......