Spring Web MVC⼊⻔

WH牛 2024-10-02 15:33:01 阅读 58

目录

1. 什么是 Spring Web MVC?

2.Spring MVC 

2.1项⽬准备

 2.2建⽴连接,@RequestMapping 注解介绍

 3.传参介绍

3.1传递单个参数

3.2传递多个参数

3.3传递对象

 3.4后端参数重命名

3.5传递数组

 3.6传递集合

3.7 传递JSON数据

 3.8获取URL中参数@PathVariable

 3.9上传⽂件@RequestPart

4.响应

4.1返回静态⻚⾯

4.2返回数据@ResponseBody

 4.3返回HTML代码⽚段

 4.4返回JSON

4.5设置状态码 


1. 什么是 Spring Web MVC?

Spring Web MVC 是基于 Servlet API 构建的原始 Web 框架,从⼀开始就包含在 Spring 框架中。它的 正式名称“Spring Web MVC”来⾃其源模块的名称(Spring-webmvc),但它通常被称为"Spring MVC".

1.什么是Servlet呢?

Servlet 是⼀种实现动态⻚⾯的技术. 准确来讲Servlet是⼀套 Java Web 开发的规范,或者说是⼀套

Java Web 开发的技术标准.(只有规范并不能做任何事情)

2.MVC 是什么?

它是软件⼯程中的⼀种软件架构设计模式,它把软件系统分 为模型、视图和控制器三个基本部分

3.什么是Spring MVC ? 

 MVC是一种思想,Spring MVC就是把 MVC思想进行了实现。Spring MVC 是⼀个实现了 MVC 模式的 Web 框架


2.Spring MVC 

2.1项⽬准备

注意:我使用的是JDK17.

Spring MVC 项⽬创建和 Spring Boot 创建项⽬相同,在创建的时候选择 Spring Web 就相当于创建了 Spring MVC 的项⽬.

 2.2建⽴连接,@RequestMapping 注解介绍

在 Spring MVC 中使⽤

@RequestMapping

来实现 URL 路由映射 ,也就是浏览器连接程序的作⽤

实现⽤⼾通过浏览器和程序的交互,具体实现代码如下:

<code>import org.springframework.web.bind.annotation.RequestMapping;

import org.springframework.web.bind.annotation.RestController;

@RestController

public class RequestController {

@RequestMapping("say")

public String say() {

return "hi Spring MVC";

}

}

接下来访问:

http://127.0.0.1:8080/say

, 就可以看到程序返回的数据了

 @RequestMapping 注解介绍

@RequestMapping

是 Spring Web MVC 应⽤程序中最常被⽤到的注解之⼀,它是⽤来注册接⼝的 路由映射的

什么是路由映射?

当⽤⼾访问⼀个 URL 时, 将⽤⼾的请求对应到程序中某个类的某个⽅法的过程就叫路由映射. 

说明: 

1.

@RequestMapping 既可修饰类,也可以修饰⽅法

,当修饰类和⽅法时,访问的地址是类路径 + ⽅ 法路径.

@RequestMapping标识⼀个类:设置映射请求的请求路径的初始信息

@RequestMapping标识⼀个⽅法:设置映射请求请求路径的具体信息

2.@RequestMapping 的URL 路径最前⾯加不加 / (斜杠)都可以, Spring程序启动时, 会进⾏判断, 如果 前⾯没有加 / , Spring会拼接上⼀个 /

3.@RequestMapping 既⽀持Get请求, ⼜⽀持Post请求. 同理, 也⽀持其他的请 求⽅式.

 3.传参介绍

我们借用postman工具

3.1传递单个参数

接收单个参数, 在 Spring MVC 中直接⽤⽅法中的参数就可以,⽐如以下方法的代码:

<code>@RequestMapping("r1")

public String r1(Integer age) {

return "返回参数:" + age;

}

结果:

 注意:

1.对于包装类型, 如果不传对应参数,Spring 接收到的数据则为null

2.

但如果形参是基础类型

如果不传对应参数,则HTTP响应状态码为400

3.2传递多个参数

和接收单个参数⼀样, 直接使⽤⽅法的参数接收即可. 使⽤多个形参

<code>@RequestMapping("r3")

public String r3(String name, Integer age) {

return "返回参数name:" + name + "age:" + age;

}

结果:

注意:

当有多个参数时,前后端进⾏参数匹配时,是以参数的名称进⾏匹配的,因此参数的位置是不影响后 端获取参数的结果,多传也无妨,少传看情况。

3.3传递对象

如果参数⽐较多时, ⽅法声明就需要有很多形参. 并且后续每次新增⼀个参数, 也需要修改⽅法声明.

我们不妨把这些参数封装为⼀个对象

比如我们封装一个学生类:

<code>public class Student {

private Integer id;

private String name;

private Integer age;

public Student(Integer id, String name, Integer age) {

this.id = id;

this.name = name;

this.age = age;

}

public Integer getId() {

return id;

}

public void setId(Integer id) {

this.id = id;

}

public String getName() {

return name;

}

public void setName(String name) {

this.name = name;

}

public Integer getAge() {

return age;

}

public void setAge(Integer age) {

this.age = age;

}

@Override

public String toString() {

return "Student{" +

"id=" + id +

", name='" + name + '\'' +code>

", age=" + age +

'}';

}

}

和接收单个参数⼀样, 直接使⽤⽅法的参数接收即可.

结果:

Spring 会根据参数名称⾃动绑定到对象的各个属性上, 如果某个属性未传递, 则赋值为null(基本类型则 赋值为默认初识值, ⽐如int类型的属性, 会被赋值为0)

 3.4后端参数重命名

某些特殊的情况下,前端传递的参数 key 和我们后端接收的 key 可以不⼀致

<code> @RequestMapping("r5")

public String r5(@RequestParam("name") String username){

return "返回参数:" + username;

}

注意:

1.

 

使⽤

@RequestParam

进⾏参数重命名时, 请求参数只能和

@RequestParam

声明的名称⼀

致, 才能进⾏参数绑定和赋值。

2.

使⽤

@RequestParam

进⾏参数重命名时, 参数就变成了必传参数。

3.

⾮必传参数设置

@RequestMapping("r5")

public String r5(@RequestParam(value = "name",required = false) String username){

return "返回参数:" + username;

}

3.5传递数组

Spring MVC 可以⾃动绑定数组参数的赋值

后端实现代码:

@RequestMapping("r6")

public String r6(String[] s){

return Arrays.toString(s);

}

数组传参方式:

1.http://127.0.0.1:8080/r6?s=aaa,bbb,ccc

2.http://127.0.0.1:8080/r6?s=aaa&s=bbb&s=ccc

 3.6传递集合

集合参数:和数组类似, 同⼀个请求参数名有为多个, 且需要使⽤

@RequestParam

绑定参数关系

<code> @RequestMapping("r7")

public String r7(@RequestParam(required = false)List<String> list){

return "返回参数:"+list;

}

结果:

3.7 传递JSON数据

JSON:理解成一种数据格式就好。

JSON的语法:

1.数据在 键值对

(Key/Value)

2.数据由逗号

,

分隔

 

3.

对象⽤

{}

表⽰

 

4.

数组⽤

[]

表⽰

5.值可以为对象, 也可以为数组, 数组中可以包含多个对象

JSON的两种结构

 

1.

对象: ⼤括号

{}

保存的对象是⼀个⽆序的 键值对 集合. ⼀个对象以左括号

{

开始, 右括号

}

结束。每个"键"后跟⼀个冒号 :

,键值对使⽤逗号

,

分隔

 

2.

数组: 中括号

[]

保存的数组是值(value)的有序集合. ⼀个数组以左中括号

[

开始, 右中括 号 ]

结束,值之间使⽤逗号

,

分隔

以下都是合法的JSON数据

<code>{"name":"admin","age":18}

["hello", 3.1415, "json"]

[{"name":"admin","age":18},{"name":"root","age":16},{"name":"张三","age":20}]

 可以使⽤在线JSON格式化⼯具来进⾏校验和书写: 在线JSON校验格式化工具(Be JSON)

icon-default.png?t=O83A

https://www.bejson.com/

JSON优点:

1.简单易⽤: 语法简单,易于理解和编写,可以快速地进⾏数据交换

2.跨平台⽀持: JSON可以被多种编程语⾔解析和⽣成, 可以在不同的平台和语⾔之间进⾏数据交换和 传输

3.轻量级: 相较于XML格式, JSON数据格式更加轻量级, 传输数据时占⽤带宽较⼩, 可以提⾼数据传输 速度

4.易于扩展: JSON的数据结构灵活,⽀持嵌套对象和数组等复杂的数据结构,便于扩展和使⽤

5.安全性: JSON数据格式是⼀种纯⽂本格式,不包含可执⾏代码, 不会执⾏恶意代码,因此具有较⾼ 的安全性

基于以上特点, JSON在Web应⽤程序中被⼴泛使⽤, 如前后端数据交互、API接⼝数据传输等.

代码:

<code> @RequestMapping("r8")

public String r8(@RequestBody Student student) {

return "返回参数:" + student.toString();

}

 结果:

 3.8获取URL中参数@PathVariable

和字⾯表达的意思⼀样, 这个注解主要作⽤在请求URL路径上的数据绑定 

默认传递参数写在URL上,SpringMVC就可以获取到

代码:

<code> @RequestMapping("r9/{id}/{name}")

public String r9(@PathVariable Integer id, @PathVariable("name") String username) {

return "返回参数 id:" + id + " username: " + username;

}

结果:

 说明:

1.如果⽅法参数名称和需要绑定的URL中的变量名称⼀致时, 可以简写, 不⽤给@PathVariable的属性赋 值, 如上述例⼦中的id变量

2.如果⽅法参数名称和需要绑定的URL中的变量名称不⼀致时, 需要@PathVariable的属性value赋值, 如上述例⼦中的userName变量

 3.9上传⽂件@RequestPart

代码:

<code> @RequestMapping("r10")

public String r10(@RequestPart("file") MultipartFile file) {

String name = file.getOriginalFilename();

return "文件名:" + name;

}

结果:


4.响应

4.1返回静态⻚⾯

创建前端⻚⾯ /html/index.html(注意路径)

html代码如下:

<code><!DOCTYPE html>

<html lang="en">code>

<head>

<meta charset="UTF-8">code>

<title>静态页面</title>

</head>

<body>

<h1>你好,我是静态页面!!!</h1>

</body>

</html>

 Spring MVC如何才能识别出来 /html/index.html 是⼀个静态⻚⾯,而不是一个字符串?

使用@Controller注解,代码如下:

@RequestMapping("res")

@Controller

public class ResponseController {

@RequestMapping("index")

public String index() {

return "/html/index.html";

}

}

结果:

4.2返回数据@ResponseBody

@ResponseBody

表⽰返回数据

加上

@ResponseBody

注解, 该⽅法就会把 "/html/index.html" 当做⼀个数据返回给前端。

<code>@RequestMapping("res")

@Controller

public class ResponseController {

@RequestMapping("indexData")

@ResponseBody

public String indexData() {

return "/html/index.html";

}

}

说明: 

@ResponseBody

既是类注解, ⼜是⽅法注解。

如果作⽤在类上, 表⽰该类的所有⽅法, 返回的都是数据, 如果作⽤在⽅法上, 表⽰该⽅法返回的是数据

多个注解时, 没有先后顺序, 先写哪个都可以

补充:

@RestController

=

@Controller

+

@ResponseBody 默认返回数据。

@Controller

: 定义⼀个控制器, Spring 框架启动时加载, 把这个对象交给Spring管理.

@ResponseBody

: 定义返回的数据格式为⾮视图, 返回⼀个 text/html 信息

 4.3返回HTML代码⽚段

后端返回数据时, 如果数据中有HTML代码, 也会被浏览器解析

 

代码:

@RequestMapping("indexData2")

@ResponseBody

public String indexData2() {

return "<h1>我是h1标签</h1>";

}

结果:

 4.4返回JSON

Spring MVC 也可以返回JSON

后端⽅法返回结果为对象

代码:

<code>@RequestMapping("getMap")

@ResponseBody

public HashMap<String, String> getMap() {

HashMap<String, String> map = new HashMap<>();

for (int i = 0; i < 5; i++) {

map.put("key" + i, "val" + i);

}

return map;

}

结果:

4.5设置状态码 

Spring MVC会根据我们⽅法的返回结果⾃动设置响应状态码, 程序员也可以⼿动指定状态码

通过Spring MVC的内置对象HttpServletResponse 提供的⽅法来进⾏设置

代码:

<code> @RequestMapping("setStatus")

@ResponseBody

public String setStatus(HttpServletResponse response) {

response.setStatus(418);

return "状态码设置成功";

}

结果:

注意:状态码不影响页面展示。


以上为我个人的小分享,如有问题,欢迎讨论!!! 

都看到这了,不如关注一下,给个免费的赞 

 



声明

本文内容仅代表作者观点,或转载于其他网站,本站不以此文作为商业用途
如有涉及侵权,请联系本站进行删除
转载本站原创文章,请注明来源及作者。