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")@ResponseBodypublic 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就返回nullHttpSession 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);}};
}

请求转发与请求重定向

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

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【数据结构】_队列

目录 1.概念 2.队列的使用 3.队列模拟实现 4.循环队列 5.双端队列 6.栈与队列的互相实现 6.1 用队列实现栈 6.2 用栈实现队列 1.概念 &#xff08;1&#xff09;队列是只允许在一端进行插入数据操作&#xff0c;在另一端进行删除数据操作的特殊线性表&#xff1b; &am…

小米标准模组+MCU 快速上手开发(一)——之固件下载

小米标准模组+MCU 开发笔记之固件下载 背景技术名词简介● 小米IoT开发者平台● 小米IoT 模组● ESP系列简介问题描述 + 解决方式问题1:固件下载是否有示例,如何下载到硬件板卡中?问题2:固件下载的官方程序是什么?在哪里?该如何使用?问题3:固件下载时,Flash和Ram 有什…

CSB ---> (XXE)XML基础

本来今天想更一下CSbeacon上线多层的内网机器的&#xff0c;但是刚好今天是年后的第一节课&#xff0c;讲的是XXE的基础&#xff0c;那就来先盘一下基础&#xff01;&#xff01; 1.XXE XXE全称是XML External Entity即xml外部实体注入攻击&#xff01;其后果会导致用户…

[bing]“gang调度 Kubernetes的并发控制和一致性机制“论点的对应的源码分析

你是一位K8S专家。请分析在Kubernates&#xff08;https://github.com/kubernetes/kubernetes.git&#xff09;项目和调度coscheduling(https://github.com/kubernetes-sigs/scheduler-plugins/tree/master/pkg/coscheduling) 插件中支撑"PodGroup的管理和调度决策涉及到对…

小程序端学习

P2 创建Uni-app 分离窗口 一样的Ctrl S P3 细节知识点 创建新的小程序页面

一种基于动态水位值的Flink调度优化算法(flink1.5以前),等同于实现flink的Credit-based反压原理

优化flink反压 说明1 flink反压介绍1.1 介绍1.2 大数据系统反压现状1.4 flink task与task之间的反压1.5 netty水位机制作用分析 2 反压优化算法3 重点&#xff01; 但是 可但是 flink1.5以后的反压过程。4 flink反压问题的查找瓶颈办法 说明 首先说明&#xff0c;偶然看了个论…

零基础学习8051单片机(十五)

本次先看书学习&#xff0c;并完成了课后习题&#xff0c;题目出自《单片机原理与接口技术》第五版—李清朝 答: &#xff08;1&#xff09;当 CPU正在处理某件事情的时候&#xff0c;外部发生的某一件事件请求 CPU 迅速去处理&#xff0c;于是&#xff0c;CPU暂时中止当前的工…

Unity之ShaderGraph如何实现水面波浪

前言 这几天通过一个水的波浪数学公式,实现了一个波浪效果,感觉成就感满满,下面给大家分享一下 首先先给大家看一下公式; 把公式转为ShaderGraph 第一行公式:waveType = z*-1*Mathf.Cos(wave.WaveAngle/360*2*Mathf.PI)+x*Mathf.Sin(WaveAngle/360*-2*Mathf.PI) 转换…

pytorch: ground truth similarity matrix

按照真实标签排序pair-wise相似度矩阵的Pytorch代码 本文仅作留档&#xff0c;用于输出可视化 Inputs: Ground-truths Y ∈ R n 1 \mathbf{Y}\in\mathbb R^{n\times 1} Y∈Rn1, Similarity matrix A ∈ R n n \mathbf{A}\in\mathbb R^{n\times n} A∈RnnOutputs: Block dia…

CogFixtureTool(坐标系、校正与定位)

坐标系 任何VisionPro图像都支持一组坐标空间&#xff0c;为表达特定特征的位置提供数字框架。最有用的空间是根空间和用户空间&#xff0c;根空间将点与原始获取图像中的像素相关联&#xff0c;用户空间用于获得校准和固定空间中的特征位置和测量值。 根空间 图像的根空间…

11、内网安全-横向移动NTLM-Relay重放Responder中继攻击LdapEws

用途&#xff1a;个人学习笔记&#xff0c;有所借鉴&#xff0c;欢迎指正&#xff01; 目录 前提知识&#xff1a; 一、横向移动-NTLM 中继攻击-Relay 重放-SMB 上线 1、CS权限转给MSF: 2、MSF: 3、添加路由&#xff1a; 4、smb_relay重发模块&#xff1a; 5、受控主机输…

【算法与数据结构】797、LeetCode所有可能的路径

文章目录 一、题目二、解法三、完整代码 所有的LeetCode题解索引&#xff0c;可以看这篇文章——【算法和数据结构】LeetCode题解。 一、题目 二、解法 思路分析&#xff1a;有向无环图&#xff08;Directed acyclic graph, DAG&#xff09;是图论中的一个概念&#xff0c;它指…

2 Nacos适配达梦数据库实现方案

1、修改源代码方式 Nacos 原生是不支持达梦数据库的,所以就要想办法让它 “支持”,因为是开源软件,我们可以从源码入手,在流行的 1.x 、2.x 或最新版本代码的基本上进行修改。 主要涉及到以下内容的修改: com/alibaba/nacos/persistence/datasource/ExternalDataS

js谐音梗创意小游戏《望子成龙》

&#x1f33b; 前言 龙年到来&#xff0c;祥瑞满天。愿您如龙般矫健&#xff0c;事业腾飞&#xff1b;如龙鳞闪耀&#xff0c;生活美满。祝您龙年大吉&#xff0c;万事如意&#xff01; 龙年伊始&#xff0c;我给各位设计了一款原创的小游戏&#xff0c;话不多说&#xff0c;直…

智能测径仪 针对设备自身抖动都做了哪些创新加强设计

关键字:测径仪外壳设计,测径仪内部结构,外壳刚性振动,产线共振现象,镜头纯手工擦拭清洗,测径仪智能防抖算法,测径仪多重防抖技术,测径仪防抖技术,测径仪自身防抖&#xff0c; 在生产过程中&#xff0c;被测物不可避免的会发生抖动&#xff0c;测径仪本身也会产生抖动,只是抖动幅…

Google插件Sider: ChatGPT Sidebar + GPTs GPT-4 Turbo Sider

Sider: ChatGPT Sidebar 可以使得满屏都是机器人&#xff0c;左侧栏可以打开访问GPT-4. 配置跳板机地址 google 搜索的右侧也有打开

政安晨:【示例演绎机器学习】(一)—— 剖析神经网络:学习核心的Keras API

打开这篇文章&#xff0c;相信您已经了解了TensorFlow的一些基础知识&#xff0c;可以用它从头开始实现一个简单模型。 如果您对这些概念还不是太清晰&#xff0c;可以浏览一下我这个栏目中的相关文章&#xff1a; 政安晨的机器学习笔记http://t.csdnimg.cn/DHcyL 尤其是其中…

利用LaTex批量将eps转pdf、png转eps、eps转png、eps转svg

1、eps转pdf 直接使用epstopdf命令&#xff08;texlive、mitex自带&#xff09;。 在cmd中进入到eps矢量图片的目录&#xff0c;使用下面的命令&#xff1a; for %f in (*.eps) do epstopdf "%f" 下面是plt保存eps代码&#xff1a; import matplotlib.pyplot as…

网络编程知识整理

目录 1.1 引言 1.2 分层 1.3 TCP/IP的分层 1.4 互联网的地址 1.5 域名服务 1.6 封装 1.7 分用 1.8 端口号 1.1 引言 很多不同的厂家生产各种型号的计算机&#xff0c;它们运行完全不同的操作系统&#xff0c;但 T C P / I P协议族允许它们互相进行通信。这一点很让人感…

消息中间件-面试题

MQ选择 一、Kafka 1、消息队列如何保证消息可靠性 消息不重复 生产者控制消费者幂等消息不丢失 生产者发送,要确认broker收到并持久化broker确认消费者消费完,再删除消息2、kafka是什么 Kafka是一种高吞吐量、分布式、基于发布/订阅的消息中间件,是Apache的开源项目。broke…