SpringMVC回顾总结笔记

MVC是一种思想而SpringMVC是具体的实现(Ioc和DI的关系)

在创建项目的时候勾选的SpringWeb框架就是SpringMVC框架
在这里插入图片描述

与浏览器建立连接

默认返回的是一个 view 视图。需要添加@ResponseBody说明返回的是json数据。@RestController是@Controller+@ResponseBody的组合注解

package app.controller;

import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.ResponseBody;
import org.springframework.web.bind.annotation.RestController;

@Controller
@RequestMapping("/web")
public class WebController {
    // 返回数据
    @GetMapping("/hello")
    @ResponseBody
    public String hello() {
        return "hello world.";
    }

    // 返回页面
    @GetMapping("/index")
    public String index() {
        return "/index.html";
    }
}

返回数据
在这里插入图片描述
返回页面
在这里插入图片描述

获取参数

参数请求类型

  1. URL传参
  2. Ajax传参
  3. Form表单传参

获取单个参数

get1:可以通过内置的servlet获取,也可以直接给定一个和前端对应的参数获取

// 1.获取单个参数
@GetMapping("/get1")
public HashMap<String, String> getParameter1(HttpServletRequest req, HttpServletResponse rep, String name) {
    return new HashMap<String, String>() {
        {
            put("req_name", req.getParameter("name"));
            put("name", name);
        }
    };
}

Postman测试get1接口
在这里插入图片描述

Fiddler抓包结果

获取对象

User对象

import lombok.Data;

@Data
public class User {
    private Integer id;
    private String name;
    private Integer age;
    private String sex;
}

get2接口

// 2.获取对象
@GetMapping("/get2")
public HashMap<String, User> getParameter2(User user) {
    return new HashMap<String, User>() {{
        put("user", user);
    }};
}

Postman测试get2接口
在这里插入图片描述
Fiddler抓包
在这里插入图片描述

获取表单参数

get3接口

// 3.Form表单+Ajax
@RequestMapping("/get3")
public HashMap<String, User> getParameter3(User user) {
    return new HashMap<String, User>() {{
        put("user", user);
    }};
}

Form表单
input标签中name属性值和后端对象字段名需要一致

<form method="get" action="/get4">
    <div>
        <h1>Form表单</h1>
        <span>用户:</span><input type="text" name="name">
        <br/>
        <span>年龄:</span><input type="number" name="age">
        <br/>
        <span>性别:</span><input type="text" name="sex">
        <br/>
        <input type="submit" value="注册">
    </div>
</form>

表单提交数据之后会自动跳转到该接口,F12查看URL时证明表单提交的数据依旧是和之前一样进行URL拼接的方式发送数据
在这里插入图片描述
前端Form表单从get改为post请求,发现表单提交的数据get3接口可以正常获取
在这里插入图片描述

获取Ajax参数

一般Ajax发起HTTP请求的时候会为了节省数据大小,采取JSON的格式传输

get3接口

// 3.Form表单+Ajax
@RequestMapping("/get3")
public HashMap<String, User> getParameter3(User user) {
    return new HashMap<String, User>() {{
        put("user", user);
    }};
}

get请求+不指定json格式+data数据不封装为json

这里就按照要求,规定JSON格式就转为JSON格式数据没要求就不做编排。按照规范编写代码,减少后续不必要的测试步骤
Ajax代码

<div>
    <h1>Ajax</h1>
    <span>用户:</span><input type="text" name="name" id="name">
    <br/>
    <span>年龄:</span><input type="number" name="age" id="age">
    <br/>
    <span>性别:</span><input type="text" name="sex" id="sex">
    <br/>
    <input type="button" value="注册" id="sub-btn">
    <br/>
    <input id="data" hidden="hidden" style="width: auto">
</div>
<script src="../js/jquery-3.7.1.min.js"></script>

<script>
    <!--请求后端接口-->
    document.getElementById("sub-btn").addEventListener("click", function () {
        $.ajax({
            url: "/get3",
            type: "get",
            //contentType: "application/json",
            data: {
                "name": document.getElementById("name").value,
                "age": document.getElementById("age").value,
                "sex": document.getElementById("sex").value
            },
            success: function (data) {
                // 后端是HashMap这种JSON数据格式的话就需要转换为字符串或者取值【这里直接取之】
                let result = document.getElementById("data");
                result.value = `name:${data.user.name}、age:${data.user.age}、sex:${data.user.sex}`;
                result.hidden = false;
            },
            error: function (xhr, status, error) {
                console.log(error);
            }
        });
    });
</script>

分析:get请求会把发送的数据以键值的形式拼接在url后,即使设定了参数类型为JSON格式,但是依旧会遵循Ajax中的data数据这种key-value格式,SpringMVC会自动根据URL的参数和对象的属性进行匹配,因此可以形成映射关系

【不建议这么写,因为已经设定了json格式,但是data数据并没有完全封装成一个json对象,这里是为了测试效果】

在这里插入图片描述

get请求+指定json格式+data数据封装为json

Ajax代码

<div>
    <h1>Ajax</h1>
    <span>用户:</span><input type="text" name="name" id="name">
    <br/>
    <span>年龄:</span><input type="number" name="age" id="age">
    <br/>
    <span>性别:</span><input type="text" name="sex" id="sex">
    <br/>
    <input type="button" value="注册" id="sub-btn">
    <br/>
    <input id="data" hidden="hidden" style="width: auto">
</div>

<script>
    <!--请求后端接口-->
    document.getElementById("sub-btn").addEventListener("click", function () {
        $.ajax({
            url: "/get3",
            type: "get",
            contentType: "application/json",
            data: JSON.stringify({
                "name": document.getElementById("name").value,
                "age": document.getElementById("age").value,
                "sex": document.getElementById("sex").value
            }),
            success: function (data) {
                // 如果后端是HashMap这种JSON数据格式的话就需要转换为字符串
                console.log(data);
                let result = document.getElementById("data");
                result.value = `name:${data.user.name}、age:${data.user.age}、sex:${data.user.sex}`;
                result.hidden = false;
            },
            error: function (xhr, status, error) {
                console.log(error);
            }
        });
    });
</script>

在这里插入图片描述

分析:接口报错400,当封装data数据格式为JSON之后,URL中的参数和后端接口get3中的参数由于无法映射成User对象,就会报错

post请求+不指定json格式+data数据不封装为json

Ajax代码

<div>
    <h1>Ajax</h1>
    <span>用户:</span><input type="text" name="name" id="name">
    <br/>
    <span>年龄:</span><input type="number" name="age" id="age">
    <br/>
    <span>性别:</span><input type="text" name="sex" id="sex">
    <br/>
    <input type="button" value="注册" id="sub-btn">
    <br/>
    <input id="data" hidden="hidden" style="width: auto">
</div>
<script src="../js/jquery-3.7.1.min.js"></script>

<script>
    <!--请求后端接口-->
    document.getElementById("sub-btn").addEventListener("click", function () {
        $.ajax({
            url: "/get3",
            type: "post",
            //contentType: "application/json",
            data: {
                "name": document.getElementById("name").value,
                "age": document.getElementById("age").value,
                "sex": document.getElementById("sex").value
            },
            success: function (data) {
                // 后端是HashMap这种JSON数据格式的话就需要转换为字符串或者取值【这里直接取之】
                let result = document.getElementById("data");
                result.value = `name:${data.user.name}、age:${data.user.age}、sex:${data.user.sex}`;
                result.hidden = false;
            },
            error: function (xhr, status, error) {
                console.log(error);
            }
        });
    });
</script>

在这里插入图片描述
分析:Ajax的post请求其实和表单的post请求类似,所以依旧可以获取到数据

post请求+指定json格式+data数据封装为json

Ajax代码

<div>
    <h1>Ajax</h1>
    <span>用户:</span><input type="text" name="name" id="name">
    <br/>
    <span>年龄:</span><input type="number" name="age" id="age">
    <br/>
    <span>性别:</span><input type="text" name="sex" id="sex">
    <br/>
    <input type="button" value="注册" id="sub-btn">
    <br/>
    <input id="data" hidden="hidden" style="width: auto">
</div>

<script>
    <!--请求后端接口-->
    document.getElementById("sub-btn").addEventListener("click", function () {
        $.ajax({
            url: "/get3",
            type: "post",
            contentType: "application/json",
            data: JSON.stringify({
                "name": document.getElementById("name").value,
                "age": document.getElementById("age").value,
                "sex": document.getElementById("sex").value
            }),
            success: function (data) {
                // 如果后端是HashMap这种JSON数据格式的话就需要转换为字符串
                console.log(data);
                let result = document.getElementById("data");
                result.value = `name:${data.user.name}、age:${data.user.age}、sex:${data.user.sex}`;
                result.hidden = false;
            },
            error: function (xhr, status, error) {
                console.log(error);
            }
        });
    });
</script>

在这里插入图片描述

分析:原因和之前get请求+指定json格式+data数据封装为json类似,转为JSON对象之后无法和get3接口中User对象进行匹配,只不过是不会报错的原因是此时post请求不用解析URL中的参数和后端接口去匹配,而是将body中的数据去匹配,此时body中的数据有JSON对象,但是无法和get3接口中的User对象进行映射,需要添加一个@RequestBody注解才能实现JSON对象和后端接口参数中的User对象进行映射

获取JSON对象@RequestBody

get5接口在对象参数前加一个@RequestBody注解
@RequestBody:将前端数据映射为一个Java对象

// 4.JSON对象+Postman测试
@RequestMapping("/get4")
public String getParameter4(@RequestBody User user) {
    return new HashMap<String, User>() {{
            put("user", user);
        }};
}

前端Ajax,url更改为get4,请求方式为post

<div>
    <h1>Ajax</h1>
    <span>用户:</span><input type="text" name="name" id="name">
    <br/>
    <span>年龄:</span><input type="number" name="age" id="age">
    <br/>
    <span>性别:</span><input type="text" name="sex" id="sex">
    <br/>
    <input type="button" value="注册" id="sub-btn">
    <br/>
    <input id="data" hidden="hidden" style="width: auto">
</div>
<script src="../js/jquery-3.7.1.min.js"></script>

<script>
    <!--请求后端接口-->
    document.getElementById("sub-btn").addEventListener("click", function () {
        $.ajax({
            url: "/get4",
            type: "post",
            contentType: "application/json",
            data: JSON.stringify({
                "name": document.getElementById("name").value,
                "age": document.getElementById("age").value,
                "sex": document.getElementById("sex").value
            }),
            success: function (data) {
                // 后端是HashMap这种JSON数据格式的话就需要转换为字符串或者取值【这里直接取之】
                let result = document.getElementById("data");
                result.value = `name:${data.user.name}、age:${data.user.age}、sex:${data.user.sex}`;
                result.hidden = false;
            },
            error: function (xhr, status, error) {
                console.log(error);
            }
        });
    });
</script>

获取文件@RequestPart

// 5.获取文件
@PostMapping("/get5")
public String getParameter5(String name, @RequestPart("myfile") MultipartFile upLoadFile) throws IOException {
    // 获取文件名
    String fileName = upLoadFile.getOriginalFilename();
    System.out.println(fileName);
    if (fileName != null) {
        String filePath = ClassUtils.getDefaultClassLoader().getResource("static").getPath() + "/";
        File file = new File(filePath + fileName);
        upLoadFile.transferTo(file);
        return "【" + file.getName() + "】上传成功";
    }
    return "上传失败";
}

Postman测接口的时候需要文件名和后端@RequestPart对应
在这里插入图片描述

获取Cookie/Session/Header

因为HTTP无状态,浏览器默认会把当前网站所有Cookie发送给后端

/***
 * 6.获取 Cookie、Session 和 Header
 * 6.1 Cookie
 * 		Servlet方式获取: 获取全部Cookie
 * 		注解方式获取: 获取1个Cookie
 */
@GetMapping("/get6")
public HashMap<String, String> getParameter6(HttpServletRequest request) {
    Cookie[] cookies = request.getCookies();
    // true: 没有session就创建一个session,false: 没有session就返回null
    HttpSession session = request.getSession(true);
    session.setAttribute("session_dir_jdk", System.getProperty("user.dir"));
    session.setAttribute("session_dir_spring", ClassUtils.getDefaultClassLoader().getResource("app").getPath());
    String userAgent = request.getHeader("User-Agent");
    return new HashMap<String, String>() {{
        put("cookies", Arrays.toString(cookies));
        put("session_dir_jdk", session.getAttribute("session_dir_jdk").toString());
        put("session_dir_spring", session.getAttribute("session_dir_spring").toString());
        put("userAgent", userAgent);
    }};
}

@GetMapping("/get7")
public HashMap<String, String> getParameter7(@CookieValue("JSESSIONID") String cookie_JSESSIONID,
                                             @SessionAttribute(value = "session_dir_jdk", required = true) String session_dir_jdk,
                                             @SessionAttribute(value = "session_dir_spring", required = true) String session_dir_spring,
                                             @RequestHeader("User-Agent") String userAgent) {
    return new HashMap<String, String>() {{
        put("cookie_JSESSIONID", cookie_JSESSIONID);
        put("session_dir_jdk", session_dir_jdk);
        put("session_dir_spring", session_dir_spring);
        put("userAgent", userAgent);
    }};
}

在浏览器手动设置Cookie
在这里插入图片描述

后端参数重命名@RequestParam

如果前后端参数未统一管理,则此时后端可以使用@RequestParam重命名前后端参数值
前端

<div>
    <input type="button" value="点击获取当前时间" id="getCurrentTIme">
    <br>
    <input type="datetime-local" hidden="hidden" id="showCurrentTime">
</div>

<script>
    // 后端参数重命名
    document.getElementById("getCurrentTIme").addEventListener("click", function () {
        let nowTimeStamp = new Date();
        let year = nowTimeStamp.getFullYear();
        let month = String(nowTimeStamp.getMonth() + 1).padStart(2, "0");
        let day = String(nowTimeStamp.getDate()).padStart(2, "0");
        let hour = String(nowTimeStamp.getHours()).padStart(2, "0");
        let min = String(nowTimeStamp.getMinutes()).padStart(2, "0");
        let sec = String(nowTimeStamp.getSeconds()).padStart(2, "0");
        let time = year + "-" + month + "-" + day + " " + hour + ":" + min + ":" + sec;
        jQuery.ajax({
            url: "/get8",
            method: "GET",
            contentType: "text/plain",
            data: {"time": time},
            success(data) {
                let showCurrentTime = document.getElementById("showCurrentTime");
                showCurrentTime.hidden = false;
                showCurrentTime.value = data;
            },
            error(xhr, status, error) {
                window.alert("error:" + error);
            }
        });
    });
</script>

后端

@GetMapping("/get8")
public String getParameter8(@RequestParam("time", required = false) String createTime) {
    return createTime;
}

此时后端字段需要一个createTime但是前端却传的是time字段,那么此时后端会无法接收到参数,作为后端程序员可以通过参数重命名接收前端参数

获取URL中参数@PathVariable

前端
127.0.0.1:8080/get9/张三/23/M
在这里插入图片描述

后端

// 获取URL中的参数
@GetMapping("/get9/{name}/{age}/{sex}")
public HashMap<String, String> getParameter9(@PathVariable String name,
                                             @PathVariable String age,
                                             @PathVariable String sex) {
    return new HashMap<String, String>() {{
        put("name", name);
        put("age", age);
        put("sex", sex);
    }};
}

请求转发与请求重定向

一般都是前端处理好,但这一块属于面试常问的问题。因此做一个小小的梳理

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/394793.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

Spring6学习技术|简要介绍+安装环境+入门案例+log4j2日志

学习材料 尚硅谷Spring零基础入门到进阶&#xff0c;一套搞定spring6全套视频教程&#xff08;源码级讲解&#xff09; 碎碎念一下吧&#xff0c;javaWeb跟完了全程。还是感觉啥也不知道&#xff0c;啥也没学会。2025年春天能找到实习吗&#xff1f;真的好担心。 环境安装 纠…

Recorder 实现语音录制并上传到后端(兼容PC和移动端)

Recorder 首页&#xff1a;https://github.com/xiangyuecn/Recorder 一、安装 npm install recorder-core二、代码部分 1. HTML页面 <template><div><el-inputv-model"ttsText"type"textarea"placeholder"请输入内容"><…

Java三大框架简介与比较

一、引言 在Java开发领域&#xff0c;三大框架——Spring、Hibernate和MyBatis&#xff0c;各自扮演着重要的角色。它们为开发者提供了不同的解决方案&#xff0c;使得开发者能够更高效地构建企业级应用。本文将分别介绍这三大框架的特点、优势以及适用场景&#xff0c;并对它…

对尾递归的理解(有哪些应用场景)

文章目录 一、递归二、尾递归三、应用场景参考文献 一、递归 递归&#xff08;英语&#xff1a;Recursion&#xff09; 在数学与计算机科学中&#xff0c;是指在函数的定义中使用函数自身的方法 在函数内部&#xff0c;可以调用其他函数。如果一个函数在内部调用自身本身&am…

初次安装Android Studio卡在gradle的解决方法

原因 国外的下载的地址无法访问才导致无法下载 解决方案 找到新建项目的保存位置找到gradle文件夹 进入文件夹 用文本打开 如图 大概一样&#xff0c;将国外地址改为国内地址 选中的这一条 国内的地址有 腾讯云提供了 Gradle 的国内镜像&#xff0c;您可以通过访问腾讯云…

4核8G服务器支持多少人同时在线访问?

腾讯云4核8G服务器支持多少人在线访问&#xff1f;支持25人同时访问。实际上程序效率不同支持人数在线人数不同&#xff0c;公网带宽也是影响4核8G服务器并发数的一大因素&#xff0c;假设公网带宽太小&#xff0c;流量直接卡在入口&#xff0c;4核8G配置的CPU内存也会造成计算…

【笔记------STM32】MX_RTC_Init()初始化RTC时RTC_ISR_INITF位超时失败的解决方法

RTC和flash有点像&#xff0c;有些功能需要解锁才能配置&#xff0c;虽然cubeMX生成的RTC部分的解锁配置正确&#xff0c;但却没有配置好前提条件&#xff1a;关闭PWR模块的备份域写保护使能&#xff0c;有点奇怪&#xff0c;手动关掉就好了 现象&#xff1a;进入RTC_EnterInit…

【C++】编译器如何识别重载函数

文章目录 前言 前言 我们都知道&#xff0c;函数重载即一个函数拥有了多个版本&#xff0c;我们使用时可以通过不同的数据类型区分我们调用的时哪一个重载函数&#xff0c;但编译器编译链接阶段对函数的调用时通过在符号表中寻找唯一名称来确定地址&#xff0c;c时怎么解决了符…

动态规划(算法竞赛)--线性DP数字三角形

1、B站视频链接&#xff1a;E01 记忆化搜索 数字三角形_哔哩哔哩_bilibili 题目要求&#xff1a;求累加的最大值 #include <bits/stdc.h> using namespace std; int n4; int a[9][9]{{1},{4,6},{8,3,9},{5,7,2,1}};//搜索树 int f[9][9];//记录从下向上的累加和 int dfs…

职场隐私守则:关系再好也别碰这些“雷区”

在职场中&#xff0c;与同事建立良好的关系是非常重要的&#xff0c;它有助于提高工作效率、增进团队协作&#xff0c;并且能够为日常的工作带来便利。 然而&#xff0c;即便与同事的关系再亲密&#xff0c;也有一些隐私话题是绝对不能轻易透露的。 在与同事和领导相处时&…

Springboot集成activiti,低代码整合平台,智慧审批,前端vue

一、项目形式 springbootvueactiviti集成了activiti在线编辑器&#xff0c;快速开发平台&#xff0c;可插拔工作流服务。 二、项目介绍 本项目拥有用户管理&#xff0c;部门管理&#xff0c;代码生成&#xff0c;系统监管&#xff0c;报表&#xff0c;大屏展示&#xff0c;业…

【漏洞复现-通达OA】通达OA share身份认证绕过漏洞

一、漏洞简介 通达OA(Office Anywhere网络智能办公系统)是中国通达公司的一套协同办公自动化软件。通达OA /share/handle.php存在一个认证绕过漏洞,利用该漏洞可以实现任意用户登录。攻击者可以通过构造恶意攻击代码,成功登录系统管理员账户,继而在系统后台上传恶意文件控…

瑞金:新春送祝福 温暖伴心间

冬日虽寒&#xff0c;人心更暖。1月15日到2月10日&#xff0c;在阿里巴巴公益、人人3小时平台和联劝公益基金会的支持和指导下&#xff0c;瑞金赋能公益开展“新春有爱-新春送祝福”主题活动。 随着新春的脚步日益临近&#xff0c;志愿者们冒着严寒穿梭在沙洲坝镇和泽覃乡&…

网络编程_TCP通信综合练习:

1 //client&#xff1a;&#xff1a; public class Client {public static void main(String[] args) throws IOException {//多次发送数据//创建socket对象,填写服务器的ip以及端口Socket snew Socket("127.0.0.1",10000);//获取输出流OutputStream op s.getOutput…

使用RK3588开发板使用 SFTP 互传-windows与开发板互传

MobaXterm 软件网盘下载路径&#xff1a;“iTOP-3588 开发板\02_【iTOP-RK3588 开发板】开发资料\04_iTOP-3588 开发板所需 PC 软件&#xff08;工具&#xff09;\02-MobaXterm”。 打开 MobaXterm 创建一个 SFTP 会话&#xff0c;如下图所示&#xff1a; 输入密码 topeet 进入…

【目标跟踪】提供一种简单跟踪测距方法(c++)

文章目录 一、前言二、c代码2.1、Tracking2.2、KalmanTracking2.3、Hungarian2.4、TrackingInfo 三、调用示例四、结果 一、前言 在许多目标检测应用场景中&#xff0c;完完全全依赖目标检测对下游是很难做出有效判断&#xff0c;如漏检。检测后都会加入跟踪进行一些判断或者说…

深入理解 Vue3 中的 setup 函数

&#x1f497;&#x1f497;&#x1f497;欢迎来到我的博客&#xff0c;你将找到有关如何使用技术解决问题的文章&#xff0c;也会找到某个技术的学习路线。无论你是何种职业&#xff0c;我都希望我的博客对你有所帮助。最后不要忘记订阅我的博客以获取最新文章&#xff0c;也欢…

文章复现 | 差异分析和PPI网络构建

原文链接&#xff1a;差异分析和PPI网路图绘制教程 写在前面 在原文中&#xff0c;作者获得285个DEG&#xff0c;在此推文中共获得601个DEG。小杜的猜想是标准化的水段不同的原因吧&#xff0c;或是其他的原因。此外&#xff0c;惊奇的发现发表医学类的文章在附件中都不提供相…

快速入门:简单几步教你如何打开 JSON 文件

在当今的开发环境中&#xff0c;无论是前端还是后端开发者&#xff0c;几乎都会碰到需要处理 JSON&#xff08;JavaScript Object Notation&#xff09;文件的情况。JSON 格式因其轻量级、易于人阅读的结构而成为数据交换的首选格式。 什么是 JSON&#xff1f; JSON&#xff…

【数据库】Mysql索引

1、什么是索引&#xff1f;为什么要用索引&#xff1f; 1.1、索引的含义 数据库索引&#xff0c;是数据库管理系统中一个排序的数据结构&#xff0c;以协助快速查询&#xff0c;更新数据库中表的数据。索引的实现通常使用B树和变种的B树&#xff08;MySQL常用的索引就是B树&am…