这里写自定义目录标题
SpringMVC
1.1、什么是MVC
- MVC: 模型(Model)、视图(View)、控制器(Controller),是一种软件设计规范,一种架构模式
- 将业务逻辑、数据、显示分离的方法组织代码;降低视图与业务逻辑之间的耦合
- Model: 数据模型,提供要展示的数据,包含了数据和行为。可以认为是领域模型或者JavaBean组件(包含数据和行为)。也就是说模型提供了模型数据查询和模型数据状态更新等功能,包括数据和业务。
- View:负责模型的展示,一般就是我们能见到的用户界面
- Controller:接受用户请求,委托给模型进行处理,处理完毕后把返回的模型数据返回给View。也就是说控制器是一个调度员的工作。
1.2、回顾Servlet
-
新建Maven工程当父工程!导入pom依赖
<dependencies> <dependency> <groupId>junit</groupId> <artifactId>junit</artifactId> <version>4.13.2</version> </dependency> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-webmvc</artifactId> <version>5.2.0.RELEASE</version> </dependency> <!--JSP依赖--> <dependency> <groupId>javax.servlet</groupId> <artifactId>servlet-api</artifactId> <version>2.5</version> </dependency> <dependency> <groupId>javax.servlet.jsp.jstl</groupId> <artifactId>jstl-api</artifactId> <version>1.2</version> </dependency> <dependency> <groupId>javax.servlet.jsp</groupId> <artifactId>jsp-api</artifactId> <version>2.2</version> </dependency> </dependencies>```
-
普通maven项目配置为Web,右击项目选择Add FrameWorkSupport,选择WebApplication
3. 导入servlet-api和jsp-api依赖
4. 自定义Servlet(request负责转发,response负责重定向)
```java
public class HelloServlet extends HttpServlet {
@Override
protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
// 获取前端的参数
String method = req.getParameter(“method”);
if(method.equals(“add”)){
req.getSession().setAttribute(“msg”, “执行了add方法”);
}else{
req.getSession().setAttribute(“msg”, “执行了delete方法”);
}// 调用业务层代码 // 视图转发或者重定向: req负责转发, resp负责重定向 req.getRequestDispatcher("/WEB-INF/jsp/test.jsp").forward(req, resp); //resp.sendRedirect();
}
@Override
15 index.jsp ```
protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
doGet(req, resp);
}5. 配置web.xml 6.
xml
hello
servlet.HelloServlet
hello
/hello/url
1.3 SpringMVC概述
- SpringMVC
- 轻量级,基于响应的MVC框架,与Spring兼容性好,无缝衔接,约定优于配置
- 功能:RESTful、数据验证、格式化、本地化、主题等等
- SpringMVC中用到的所有bean都会被注册到Spring容器中
- DispatcherServlet
- SpringMVC是基于DidpatcherServlet的一个请求分发的原理
1.4 第一个SpringMVC程序
- 重点是SpringMVC的url处理器和url适配器
- URL处理器: org.springframeword.web.servlet.handler.BeanNameUrlHandlerMapping
- URL适配器:org.springframework.web.servlet.mvc.SimpleControllerHandlerAdapter
- 新建Module
- 配置spring-servlet.xml
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans.xsd">
<!--添加bean处理映射器-->
<bean class="org.springframework.web.servlet.handler.BeanNameUrlHandlerMapping"/>
<!--添加处理器适配器-->
<bean class="org.springframework.web.servlet.mvc.SimpleControllerHandlerAdapter"/>
<!--添加视图解析器-->
<bean class="org.springframework.web.servlet.view.InternalResourceViewResolver">
<!--前缀-->
<property name="prefix" value="/WEB-INF/jsp/"/>
<!--后缀-->
<property name="suffix" value=".jsp"/>
</bean>
</beans>
- 配置web.xml
<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns="http://xmlns.jcp.org/xml/ns/javaee"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/javaee http://xmlns.jcp.org/xml/ns/javaee/web-app_4_0.xsd"
version="4.0">
<servlet>
<servlet-name>springmvc</servlet-name>
<servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
<!--关联一个springmvc的配置文件-->
<init-param>
<param-name>contextConfigLocation</param-name>
<param-value>classpath:spring-servlet.xml</param-value>
</init-param>
<!--启动级别为1级-->
<load-on-startup>1</load-on-startup>
</servlet>
<servlet-mapping>
<servlet-name>springmvc</servlet-name>
<!--/ 匹配所有的请求: 不包括jsp-->
<!--/* 匹配所有的请求: 包括jsp-->
<url-pattern>/</url-pattern>
</servlet-mapping>
</web-app>
- 书写处理请求的Controller
public class HelloController implements Controller {
@Override
public ModelAndView handleRequest(HttpServletRequest httpServletRequest, HttpServletResponse httpServletResponse) throws Exception {
// ModelAndView模型和视图
ModelAndView mv = new ModelAndView();
// 封装对象,放在ModelAndView中
mv.addObject("msg", "HelloSpringMVC");
mv.setViewName("hello"); // 根据配置,自动拼接前后缀(/WEB-INF/jsp/hello.jsp)
return mv;
}
}
- 在bean中注册Controller
<bean id="/hello" class="com.miao.controller.HelloController"/>
- 404问题,项目中没有导入lib中的jar包,点击项目结构,新建lib导入jar包
1.5 SpringMVC原理
- HandlerMapping为处理器映射,DispathcherServlet调用HandlerMapping,HandlerMapping根据请求url查找Handler
- HandlerExecution表示具体的Handler,根据url查找控制器,上面所找到的控制器Controller名称为:hello
- HandlerExecution将解析后的信息传递给DispatcherServlet,如解析控制器映射等
- HandlerAdapter表示处理器适配器,将按照规定去执行Handler
- Handler会让具体的Controller执行
- Controller将具体的执行信息返回给HandlerAdapter,如ModelAndView
- HandlerAdapter将视图逻辑名或者模型传递给DispatcherServlet
- DispatcherServlet根据视图解析器解析视图结果
1.6 注解实现SpringMVC
- web.xml
<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns="http://xmlns.jcp.org/xml/ns/javaee"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/javaee http://xmlns.jcp.org/xml/ns/javaee/web-app_4_0.xsd"
version="4.0">
<servlet>
<servlet-name>SpringMVC</servlet-name>
<servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
<init-param>
<param-name>contextConfigLocation</param-name>
<param-value>classpath:springmvc-servlet.xml</param-value>
</init-param>
<load-on-startup>1</load-on-startup>
</servlet>
<servlet-mapping>
<servlet-name>SpringMVC</servlet-name>
<url-pattern>/</url-pattern>
</servlet-mapping>
</web-app>
- springmvc-servlet.xml:
- 导入context 自动扫描包(这样添加注解就能自动注入bean)
- mvc: default-servlet-handler 配置默认mvc处理器
- mvc注解驱动: mvc:annotation-driven
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns:context="http://www.springframework.org/schema/context"
xmlns:mvc="http://www.springframework.org/schema/mvc"
xsi:schemaLocation="http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans.xsd
http://www.springframework.org/schema/context
https://www.springframework.org/schema/context/spring-context.xsd
http://www.springframework.org/schema/mvc
https://www.springframework.org/schema/mvc/spring-mvc.xsd">
<!-- 自动扫描包,让指定包下的注解生效,由IOC容器统一管理 -->
<context:component-scan base-package="com.kuang.controller"/>
<!-- 让Spring MVC不处理静态资源 -->
<mvc:default-servlet-handler />
<!--
支持mvc注解驱动
在spring中一般采用@RequestMapping注解来完成映射关系
要想使@RequestMapping注解生效
必须向上下文中注册DefaultAnnotationHandlerMapping
和一个AnnotationMethodHandlerAdapter实例
这两个实例分别在类级别和方法级别处理。
而annotation-driven配置帮助我们自动完成上述两个实例的注入。
-->
<mvc:annotation-driven />
<!-- 视图解析器 -->
<bean class="org.springframework.web.servlet.view.InternalResourceViewResolver"
id="internalResourceViewResolver">
<!-- 前缀 -->
<property name="prefix" value="/WEB-INF/jsp/" />
<!-- 后缀 -->
<property name="suffix" value=".jsp" />
</bean>
</beans>
- Controller
@Controller
public class HelloController {
@RequestMapping("/hello")
public String sayHello(Model model){
model.addAttribute("msg", "Hello Spring");
return "hello";
}
}