什么是MVC
MVC是一种软件架构的思想,将软件按照模型、视图、控制器来划分。
M:Model,模型层,指工程中的JavaBean,作用是处理数据。
JavaBean分为两类:
1. 实体类Bean:专门存储业务数据的,如 Student、User 等。
2. 业务处理 Bean:Service 或 Dao 对象,用于处理业务逻辑和数据访问。
V:View,视图层,指前端中的html或jsp等页面,作用是与用户进行交互,展示数据。
C:Controller,控制层,指工程中的servlet,作用是接收请求和响应浏览器。
MVC的工作流程:
用户通过视图层发送请求到服务器,在服务器中请求被Controller接收,
Controller调用相应的Model层处理请求,处理完毕将结果返回到Controller,
Controller再根据请求处理的结果找到相应的View视图,渲染数据后最终响应给浏览器。
注意:三层架构分为表述层(或表示层)、业务逻辑层,数据访问层,表述层表示前台页面和后台servlet。
SpringMVC的特点
Spring 家族原生产品,与 IOC 容器等基础设施无缝对接。
基于原生的Servlet,通过了功能强大的前端控制器DispatcherServlet,
对请求和响应进行统一处理(springmvc封装了servlet为前端控制器DispatcherServlet)
表述层各细分领域需要解决的问题全方位覆盖,提供全面解决方案。
代码清新简洁,大幅度提升开发效率。
内部组件化程度高,可插拔式组件即插即用,想要什么功能配置相应组件即可。
性能卓著,尤其适合现代大型、超大型互联网项目要求。
入门案例
添加依赖:
- spring-webmvc(SpringMVC):
springmvc是基于spring基础运行的,这个依赖会把spring依赖间接引入进来。
- logback-classic(日志 ):
thymeleaf必须要依赖self4j是日记的门面,也就是日记的接口,
想要实现slf4j,就要找到日记门面的实现,而logback就是self4j的门面。
- javax.servlet-api(ServletAPI):
servlet所用到的所有API都在这个依赖里面了。
- thymeleaf-spring5:Spring5和Thymeleaf整合包
配置web.xml
为什么配置web.xml
因为springmvc把servlet实现的的功能进行了封装成了DispatcherServlet前端控制器。
就是注册当前springmvc所封装之后的前端控制器DispatcherServlet。
配置springmvc的前端控制器DispatcherServlet
servlet-name:servlet里面的servlet-name要跟servlet-mapping里面的servlet-name一致
url-pattern:servlet-mapping 里面的url-pattern是springmvc前端控制器
要来处理的请求的路径模型。所以浏览器向服务器发送的请求
都要被DispatcherServlet统一进行处理。
url-pattern里面所写的内容:/ & /*
/ :匹配的是浏览器向服务器发送的所有请求,不能匹配.jsp的方式
/* :表示匹配任意请求
为什么尽量写/:jsp本质是servlet,jsp的访问方式都是.jsp,
jsp是不能被DispatcherServlet进行处理,因为在tomcat.xml里面
已经配置过servlet专门处理jsp的请求的,叫jspservlet。
<!-- 配置springmvc的前端控制器DispatcherServlet-->
<servlet>
<!-- servlet-name里面的内容要跟servlet-mapping的servlet-name一致 -->
<servlet-name>SpringMVC</servlet-name>
<servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
</servlet>
<servlet-mapping>
<servlet-name>SpringMVC</servlet-name>
<!-- url-pattern:springmvc前端控制器要来处理的请求的路径模型 -->
<url-pattern>/</url-pattern>
</servlet-mapping>
SpringMVC配置文件
springmvc的配置文件默认的位置和名称:
位置:WEB-INF下(以后不会放到web-INF下,而是放到resources下)
WEB-INF下:浏览器不能直接访问WEB-INF下的资源,
具有一定的安全性,只能通过服务器来访问。
名称:<servlet-name>的值+-servlet.xml
配置tomcat环境时:
Application context:访问tomcat里面某个工程,就是通过上下文路径访问的。
springmvc配置文件
<!-- 扫描控制层组件 -->
<context:component-scan base-package="com.atguigu.controller"></context:component-scan>
<!-- 配置Thymeleaf视图解析器 -->
<bean id="viewResolver"
class="org.thymeleaf.spring5.view.ThymeleafViewResolver">
<property name="order" value="1"/>
<property name="characterEncoding" value="UTF-8"/>
<property name="templateEngine">
<bean class="org.thymeleaf.spring5.SpringTemplateEngine">
<property name="templateResolver">
<bean
class="org.thymeleaf.spring5.templateresolver.SpringResourceTemplateResolver">
<!-- 视图前缀 -->
<property name="prefix" value="/WEB-INF/templates/"/>
<!-- 视图后缀 -->
<property name="suffix" value=".html"/>
<property name="templateMode" value="HTML5"/>
<property name="characterEncoding" value="UTF-8" />
</bean>
</property>
</bean>
</property>
</bean>
浏览器(客户端)和服务端
html
index.html
<h1>index.html</h1>
<!--/ 是绝对路径,由浏览器解析这个/会解析成localhost:8080,没有上下文路径-->
<!-- <a href="/hello"></a> -->
<!--用thymeleaf访问这个路径,会自动把上下文路径加上-->
<a th:href="@{/hello}">测试SpringMVC</a>
success.html
<head>
<meta charset="UTF-8">
<title>跳转成功页面</title>
</head>
<body>
<h1>success.html</h1>
</body>>
控制层controller
处理请求的方法
处理访问首页的方法,方法的类型是String因为逻辑视图是字符串类型。
RequestMapping注解:可以把当前浏览器发送的请求映射到这个方法来执行, value值:当浏览器发送一个请求,如果这个请求路径
跟当前RequestMapping的value属性值所设置的一样,
那这个方法就是处理请求的方法。
/绝对路径:浏览器解析和服务器解析。
在服务器写的就是给服务器解析成 localhost:8080/上下文路径 。
由浏览器解析的/会解析成localhost:8080,没有上下文路径。
可以用thymeleaf访问这个路径,会自动把上下文路径加上。
处理index这个请求方法
@RequestMapping("/")
public String protal(){
// 将逻辑视图返回,会被springmvc的配置文件所配置的视图解析器来解析,然后把逻辑视图加上前后缀,
// 就匹配到完整的物理视图了,通过thymeleaf渲染跳转到这个页面
return "index";
}
处理hello路径这个请求方法
@RequestMapping("/hello")
public String hello(){
return "success";
}
SpringMVC配置文件扩展
设置DispatcherServlet要加载的springmvc配置文件的路径
<servlet>
<init-param>
<param-name>contextConfigLocation</param-name>
<!-- classpath:不写还是指的是WEB-INF下,classpath指的还是类路径 -->
<param-value>classpath:springmvc.xml</param-value>
</init-param>
将DispatcherServlet初始化时间提前到服务器启动时
<load-on-startup>1</load-on-startup>
</servlet>