MVC(Model-View-Controller)是一种常见的软件设计模式,用于将应用程序的逻辑分离成三个独立的组件:
MVC设计模式的作用如下:
总的来说,MVC设计模式通过将应用程序的逻辑分离成模型、视图和控制器,提供了一种结构化的开发方式,使得代码更加可读、可维护和可扩展,同时改善了用户体验和开发效率。
Spring Web MVC是基于Servlet API构建的原始Web框架,也是Spring框架的一部分。它提供了灵活可扩展的MVC架构,方便开发者构建高性能的Web应用程序,并与 Spring 生态系统无缝集成。
Spring MVC与MVC之间的关系的要点总结:
综上所述,Spring MVC是Spring框架提供的基于MVC架构并继承了Servlet API的Web开发框架。它遵循MVC模式的原则,提供了一套完整的开发流程和特性。通过Spring框架的支持,它能够实现灵活性、可配置性和可扩展性,帮助开发者构建高性能的Web应用程序。
注意:既然是 Web框架,那么当用户在浏览器中输入了url之后,我们的Spring MVC 项目就可以感知到用户的请求。
现在的项目大部分Java项目都是基于Spring或者Spring Boot的,而Spring 的核心就是Spring MVC。
简单来说,Spring MVC是一切项目的基础,我们以后创建的所有Spring、Spring Boot项目基本都是基于Spring MVC的。
在创建Spring Boot项目时,我们勾选的Spring Web框架其实就是Spring MVC框架。
学习Spring MVC,我们只需要掌握以下3个功能:
1.连接的功能︰将用户(浏览器)和 Java 程序连接起来,也就是访问一个地址能够调用到我们的Spring程序。
2.获取参数的功能︰用户访问的时候会带一些参数,在程序中要想办法获取到参数。
3.输出数据的功能︰执行了业务逻辑之后,要把程序执行的结果返回给用户。
Spring MVC项目的创建方式有2种,分别为:
由于第一种方式中的过程较复杂,而第二种方式较为简单,故在2018年以后基本都是使用第二种方式来进行创建Spring MVC项目。
Spring MVC项目创建和Spring Boot 项目创建基本相同,只需要在创建的时候选择Spring Web 框架就相当于创建了Spring MVC项目。
在Spring MVC项目中实现连接操作之前,我们需要先解决一个问题:何为路由映射?
所谓的路由映射指的是,当用户访问一个url时,将用户的请求对应到程序中某个类的某个方法的过程。
Spring MVC项目实现连接的操作就与路由映射密切相关,实现路由映射可以使用注解。
用来实现注册接口的路由映射的常见注解有@RequestMapping
,@PostMapping
,@GetMapping
。
1,@RequestMapping注解
@RequestMapping注解的基本使用:
@RequestMapping注解的基本用法说明:
method
属性来进行限定处理请求的HTTP方法。2,@PostMapping注解
@PostMapping注解的基本使用:
@PostMapping注解的基本用法说明:
3,@GetMapping注解
@GetMapping注解的基本使用:
@GetMapping注解的基本用法说明:
4,三类注解区别总结
三类注解区别总结归纳:
5,GET请求的映射方式
1)使用@GetMapping
注解
2)使用RequestMapping
注解
3)使用RequestMapping
注解并搭配method
属性
获取单个参数的操作代码:
对操作代码进行运行检测:
获取单个参数注意说明:
1)代码中声明的参数名与请求地址栏中的参数名要完全一致,若不一致则无法获取到地址栏中对应的参数值,会为参数的默认值。
2)如果想明确指定请求中的参数要绑定到处理方法的参数,可以在处理方法的参数前使用@RequestParam注解进行参数重命名操作。
对操作代码进行运行检测:
获取多个参数的操作代码:
对操作代码进行运行检测:
获取多个参数注意说明:
1)进行参数匹配时,后端代码的参数名称要与地址栏中的参数名称要保证完全一致。
2)前后端进行参数匹配时,是以参数的名称进行匹配的,因此地址栏中的参数位置是不影响后端获取参数的结果。
实体类UserEntity
创建:
获取普通对象的操作代码:
对操作代码进行运行检测:
获取普通对象注意说明:
1)Spring MVC 会根据地址栏中输入的参数列表自动实现参数对象的赋值操作。
获取Json对象的操作代码:
对操作代码进行运行检测:
从上述的运行检测中,发现无法接收成功 Json对象,尽管上述代码可以接收获取到普通对象。那怎样才能成功接收Json对象呢?
在Spring MVC 中,提供了 @RequestBody
注解来实现接收 Json 对象的操作。获取 Json对象的操作代码如下:
对操作代码进行运行检测:
获取基础URL参数的操作代码:
对操作代码进行运行检测:
获取基础URL参数注意说明:
1)使用@PathVariable
注解进行获取URL中的基础参数操作。
2)基础URL里面的参数是 ?之前的参数,而不是 ?之后的参数(参数列表内的参数)。
3)进行参数匹配时,后端代码的参数名称要与地址栏中的参数名称要保证一致且其对应的参数值要对应。
获取上传文件的操作代码:
对操作代码进行运行检测:
打开指定的路径进行验证文件是否成功上传,观察到文件成功上传并且文件名为指定的img.png
,说明文件成功上传。
上述操作虽然能够实现获取上传文件,但也存在明显的不足缺陷,那就是指定文件路径中只能有一个文件。为什么会出现这种情况呢?
那是因为文件名已经在代码中确定了,只能为img.png
,当上传成功一个文件后,后续成功上传的文件会覆盖之前的文件。
那若想解决这个覆盖问题,实现指定文件路径中有多个文件,该怎么办呢?
出现上述这种情况的原因是文件名确定死了,所以我们就只需要从文件名入手即可,也就是让文件名不确定死。
如果想让文件名不确定死,我们可以使用UUID.randomUUID
进行随机生成一组32位数的16进制数字所构成的文件名。
获取上传文件的改进代码:
对操作代码进行运行操作后,再打开指定文件目录下,发现不会出现上述情况了,能够实现指定文件路径中有多个文件。
获取Header的操作代码:
在地址栏中输入相关URL后,使用抓包工具进行抓包操作,抓取该请求的相关请求和响应信息。
获取Header的注意事项:
1)使用@RequestHeader
注解进行获取Header中的参数操作,该注解里的参数的参数名要与Header里面的参数名要一致。
获取Cookie的操作代码:
手动构造Cookie操作流程:
获取Cookie的操作代码运行结果:
1)使用@CookieValue
注解进行获取Cookie的操作,该注解里的参数的参数名要与Cookie列表里面的Cookie名要一致。
获取Session的操作代码:
存储Session的操作代码运行检测:
获取Session的操作代码运行检测:
获取Session的注意事项:
1)使用@SessionAttribute
注解进行获取Session的操作,该注解里的参数的参数名要与Session列表里面的Session名要一致。
2)存储Session操作没有与之对应的注解,只有获取Session操作才有对应的注解@SessionAttribute
进行简便获取。
3)Cookie能通过手动添加,但Session不能手动添加,只能通过代码进行Session创建后添加,故可知Session比Cookie更安全。
静态页面代码:
返回静态页面操作代码:
注意说明:如果index.html不加/
,表示在当前目录下查找该文件,如果加了/
,表示在根目录下查找该文件。
操作代码运行后,具进行查看输出数据是否为静态网页。
返回文本数据操作代码:
操作代码运行后,通过抓包工具进行查看输出数据的格式是否为文本数据格式。
返回Json对象操作代码:
操作代码运行后,通过抓包工具进行查看输出数据的格式是否为Json对象格式。
这就是本期博客的全部内容啦!如果有什么其他的问题无法自己解决,可以在评论区留言哦!
最后,如果你觉得这篇文章写的还不错的话或者有所收获的话,麻烦小伙伴们动动你们的小手,给个三连呗(点赞,评论✍,收藏),多多支持一下!各位的支持是我最大的动力,后期不断更新优质的内容来帮助大家,一起进步。那我们下期见!