现在项目的开发基本都是依赖于SSM,即SpringBoot + SpringMVC + MyBatis,其中,SpringMVC 框架主要是用来便于开发者进行网页开发。Spring MVC 是基于 Servlet API 构建的原始 Web 框架,从⼀开始就包含在 Spring 框架中。
什么是MVC:
MVC 是 Model View Controller 的缩写,它是软件⼯程中的⼀种软件架构模式,它把软件系统分为模型、视图和控制器三个基本部分:
data:image/s3,"s3://crabby-images/cd799/cd799959f7d9b5016842ade9b14adbdc825758f2" alt=""
MVC 和 SpringMVC 的关系:
MVC 是⼀种思想,⽽ Spring MVC 是对 MVC 思想的具体实现。
创建SpringMVC 项目:
使用SpringBoot 来创建,只需要在创建项目时添加web依赖就可以:
data:image/s3,"s3://crabby-images/8dc41/8dc41f2abf5f6bcc76326444a845e6d18ad335f8" alt=""
1. 实现连接的功能:将⽤户(浏览器)和 Java 程序连接起来,也就是访问⼀个地址能够调⽤到我们的Spring 程序。
在 Spring MVC 中使⽤ @RequestMapping 来实现 URL 路由映射,也就是浏览器连接程序的作⽤。
路由映射:所谓的路由映射指的是,当用户访问⼀个 url 时,将⽤户的请求对应到程序中某个类的某个⽅法的过程就叫路由映射。
@RequestMapping 即可修饰类,也可以修饰⽅法,当修饰类和⽅法时,访问的地址是类 + ⽅法(类和方法上方注解中的value值);当只有方法被修饰时,直接访问方法就可以,此外该注解支持多种http请求方法,通过修改method属性值进行更改。
data:image/s3,"s3://crabby-images/19801/19801e9e4f45656b815f5cccef180678e7bcf08a" alt=""
data:image/s3,"s3://crabby-images/39b2b/39b2b4faf336b955242e1a7c1a8626e53e4c7585" alt=""
仅支持单一http方法的注解:
data:image/s3,"s3://crabby-images/f3910/f3910a1e5e5ebad6b49d500cb549528e8a4ecefa" alt=""
2.实现获取参数的功能
2.1 获取单个参数
当@RequestMapping注解中的value值不加"/"时,会根据类上的注解中的value值进行相对路径的定位。一般情况下还是加"/"比较好,防止出错。
data:image/s3,"s3://crabby-images/54ce5/54ce57bfbe6c2cfefb08762803b0291fcc5d6899" alt=""
data:image/s3,"s3://crabby-images/16bf5/16bf5656959511ca4cb011b0908f666b5e052b75" alt=""
2.2 获取多个参数
data:image/s3,"s3://crabby-images/8ea44/8ea449cd65ba158acec29d0682fb64f23fa7de37" alt=""
传入的多个参数之间用"&"连接:
data:image/s3,"s3://crabby-images/2c347/2c347d37004a8a51938488d613cb763e758944e4" alt=""
获取多个参数,并对参数重命名,该情况是发生在前后端对参数的命名不一致时使用:
data:image/s3,"s3://crabby-images/0eb37/0eb37ab036ff59c074f3a46071f3ce28e07733b8" alt=""
data:image/s3,"s3://crabby-images/676ef/676ef36e3b763a66a4cbfaca5a186351f1c7dab5" alt=""
@RequestParam 注解默认情况下其修饰的变量为必须传入,不传参会报错,修改其属性,required = false 即可改变,另外,该注解主要是用于获取HTTP get方法中的query string信息,也就是utl中"?"之后的参数。
data:image/s3,"s3://crabby-images/bcc66/bcc66dda49cd9cbf06313b6769a36ebd56674753" alt=""
修改后:
data:image/s3,"s3://crabby-images/58304/5830419d5ecc0d13aa1df4444891081d85f50628" alt=""
data:image/s3,"s3://crabby-images/40043/4004341cd07d6d551037be1ef60cafb7fb456efc" alt=""
2.3 获取一个对象
普通格式的数据:
data:image/s3,"s3://crabby-images/aa70b/aa70bc5b771b59af9a931475077bfb8f8a69e779" alt=""
data:image/s3,"s3://crabby-images/e9ef1/e9ef1ddf1fcd8d3b3d6269101dfed3b946ab7135" alt=""
json 格式的数据(通过postman来构造数据):
data:image/s3,"s3://crabby-images/b86c4/b86c484800f6c34cbce0d28b6049620477016ecd" alt=""
@RequestBody 注解,主要是用于获取post请求中body部分的数据,根据请求头中的Content-Type来确定body部分的数据,再根据代码中的参数类型进行参数的转换:
data:image/s3,"s3://crabby-images/49745/49745c8bcd5ad90225835042863491a697da4540" alt=""
2.4 从基础URL 中获取参数
@PathVailable 注解,主要是用于从URL 基础路径中获取参数,也就是从URL "?"之前的路径中获取参数,其默认情况下也是要必须传入参数,否则会报错,通过required属性进行修改:
data:image/s3,"s3://crabby-images/dd816/dd8161570fd46f584a38eaca802be0787b275338" alt=""
data:image/s3,"s3://crabby-images/f02b0/f02b09e261c595f101d7aeb2270a69ac6298c26d" alt=""
2.5 上传文件
@RequestPart 注解用于将 multipart/form-data 类型的请求映射到控制器处理方法的参数中。这个注解可以用于处理文件上传的情况。
data:image/s3,"s3://crabby-images/97ab6/97ab6fdd2f61843e11618887b893443099e0bd13" alt=""
使用postman 来上传文件:
data:image/s3,"s3://crabby-images/698d7/698d7031948817d211b13e36e02e88a19a3888a8" alt=""
此时,还存在一个问题,后续上传的文件会将前面的文件覆盖,解决办法,对每次上传的文件给一个独一无二的文件名:
data:image/s3,"s3://crabby-images/21000/21000d8d36e20fb25d8007aed9ad4ef289a8a983" alt=""
2.6 获取cookie
传统方式获取cookie:
data:image/s3,"s3://crabby-images/c57cf/c57cf1f420f31a515c6c3bbc036543810bdd5207" alt=""
在网页设置两个cookie:
data:image/s3,"s3://crabby-images/c7e80/c7e80c841fd855a167df274d1d8c7731d78e3597" alt=""
查看运行结果:
data:image/s3,"s3://crabby-images/3fd37/3fd378f372c3b9b7740aa4ec7b6f855bd1ed8034" alt=""
通过注解来获取cookie:
data:image/s3,"s3://crabby-images/126f6/126f6fe54db2db894eaaaf2b7e83e8edf806e839" alt=""
运行结果:
data:image/s3,"s3://crabby-images/7b0ae/7b0ae57b3ffb57cb4a868300e87fb00c790feab6" alt=""
2.7 获取header
传统方式:
data:image/s3,"s3://crabby-images/eda1b/eda1b6f37349cfafe563db6e99bba7caa4391c60" alt=""
data:image/s3,"s3://crabby-images/0e53f/0e53f1f57bbd7d43c9fd298b7f4d973a9020f36f" alt=""
通过注解来获取:
data:image/s3,"s3://crabby-images/425c1/425c1b353734d83279d1af9440d931d353d14d97" alt=""
data:image/s3,"s3://crabby-images/f43fb/f43fbf0a3c93381e87f7df4e30e3feda3a724c0b" alt=""
2.8 获取session
先进行session 的设置,然后进行获取:
data:image/s3,"s3://crabby-images/bf884/bf88471690f8c5a393e6f43102151f77bea16799" alt=""
运行结果:
data:image/s3,"s3://crabby-images/e1cad/e1cad6296e830eacc7cd3777df62b4018914546e" alt=""
3. 返回数据
3.1 返回非静态页面数据
类上方加注解 @RequestBody,上述获取到数据,并在页面显示均是这种方式。
3.2 返回静态页面数据
去掉上述注解,返回静态页面文件:
data:image/s3,"s3://crabby-images/453ad/453add7d6afd5c301c298635cd3b29c77c759bf6" alt=""
data:image/s3,"s3://crabby-images/74df4/74df41aea7f15a3ae11d5849dbcebe1057128ec8" alt=""
3.3 请求转发和请求重定向
forward: 请求转发
redirect: 请求重定向
区别:
-
请求重定向(redirect)将请求重新定位到资源;请求转发(forward)服务器端转发。
-
请求重定向地址发⽣变化,请求转发地址不发⽣变化。
-
请求重定向与直接访问新地址效果⼀直,不存在原来的外部资源不能访问;请求转发服务器端转发有可能造成原外部资源不能访问。
示例:
请求转发:
data:image/s3,"s3://crabby-images/a3401/a3401c33a4c9bcdc7844983a047c7e816a7b044a" alt=""
url 地址不发生变化:
data:image/s3,"s3://crabby-images/63ac2/63ac2df331f34f07d8f2aba5abaa12498908bbde" alt=""
请求重定向:
data:image/s3,"s3://crabby-images/59efa/59efa182b99d56bb8be84f701eff945a0055779b" alt=""
可以看到在请求发送的一瞬间,url发生变化:
data:image/s3,"s3://crabby-images/e9ffd/e9ffdf5c26e78ef2c179a65dd75f1236dcb1981a" alt=""
下面代码中,第一部分执行成功,第二部分无法访问,因为请求转发是由服务器访问,其无法访问外部资源。
data:image/s3,"s3://crabby-images/95a5e/95a5e781ddb18fcb79745fab386091ee58efb2e6" alt=""
data:image/s3,"s3://crabby-images/27c91/27c910f8b80a865dabfdf0d76a3116faa7557e5d" alt=""
SpringBoot 开启热部署
添加依赖(图示添加是使用的Edit Starters插件):
data:image/s3,"s3://crabby-images/9cab4/9cab408f96b815cc0f8be80542f840152d5c7f4e" alt=""
需要在当前项目和新项目部分都做更改:
data:image/s3,"s3://crabby-images/0010a/0010a9e956f8c0710b4b141844fc36c94ccc4f63" alt=""
当前项目:
data:image/s3,"s3://crabby-images/7e2c4/7e2c4ad69e4f67dfbb5d054c76971ee1fe0e2658" alt=""
data:image/s3,"s3://crabby-images/b2786/b2786f97d647939eae8523b2d8887cd9a8650154" alt=""
新项目:
data:image/s3,"s3://crabby-images/9a06e/9a06ef51e4cfc2fff8ae7c0cc0f05f7c5a1d3d28" alt=""