SpringMVC
Spring集成web环境
- ApplicationContext应用上下文获取方式
- 通过new ClasspathXmlApplicationContext(Spring配置文件)方式获取的,但是每次从容器中获得Bean时都要编写
- 在Web项目中,可以使用ServletContextListener监听Web应用的启动,可以在Web应用启动时,就加载Spring的配置文件,创建应用上下文对象ApplicationContext,在将其存储到最大的域servletContext域中,这样就可以在任意位置从域中获得应用上下文的对象
- 步骤 :
- 配置ContextLoaderListener监听器
- 使用WebApplicationContextUtils获得应用上下文
web.xml的配置 :
<!--全局初始化参数-->
<context-param>
<param-name>contextConfigLocation</param-name>
<param-value>classpath:applicationContext.xml</param-value>
</context-param>
<!--配置监听器-->
<listener>
<listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
</listener>
UserSevlet 类实现资源的展示
@WebServlet("/userSevlet")
public class UserSevlet extends HttpServlet {
@Override
protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
ServletContext servletContext = req.getServletContext();
//ApplicationContext app = (ApplicationContext) servletContext.getAttribute("app");
ApplicationContext app = WebApplicationContextUtils.getWebApplicationContext(servletContext);
//ApplicationContext app = WebApplicationContextUtils.getWebApplicationContext(servletContext);
UserService bean = app.getBean(UserService.class);
bean.save();
}
}
SpringMVC的简介
- SpringMVC是一种基于Java的实现MVC设计模型的请求驱动类型的轻量级Web框架,属于SpringFrameWork的后续产品,已经融合在Spring Web Flow中。
- 通过一套注解,让一个简单的Java类成为处理请求的控制器,而无须实现任何接口,同时支持RESTful编程风格的请求
- SpringMVC的快速入门 :
- 开发步骤 :
- 导入SpringMVC的相关坐标
- 配置SpringMVC的核心控制器DispathcerSevlet
- 创建 Controller 类和视图页面
- 使用注解配置Controller类中业务方法的映射地址
- 配置SpringMVC核心文件spring-mvc.xml
- 客户端请求测试
- 开发步骤 :
SpringMVC的相关部件
- 前端控制器 : DispatcherServlet
- 处理器映射器 : HandlerMapping
- 处理器适配器 : HandlerAdapter
- 处理器 : Handler
- 视图解析器 : ViewResolver
- 视图 : View
SpringMVC的组件解析
- SpringMVC的执行过程
- 用户发送请求至前端控制器DispathcherServlet
- DispathcherServlet收到请求调用HandlerMapping处理器映射器
- 处理器映射器找到具体的处理器(可以根据xml配置,注解进行查找),生成处理器对象及处理器拦截器一并返回给DispathcherServlet
- DispathcherServlet调用HandlerAdapter处理器适配器
- HandlerAdapter经过适配器调用具体的处理器
- Controller执行完成返回ModelAndView
- HandlerAdapter将controller执行结果ModelAndView返回给DispathcherServlet
- DispathcherServlet将ModelAndView传给ViewReslover视图解析器
- ViewReslover解析后返回具体View
- DispathcherServlet根据View进行渲染视图,DispathcherServlet响应用户
- SpringMVC注解解析
- @RequestMapping : 用于建立请求URL和处理请求方法之间的对应关系
- 位置 :
- 类上,请求URL的第一级访问目录,此处不写的话,就相当于应用的根目录
- 方法上,请求URL的第二级访问目录,与类上的使用@RequestMapping标注的一级目录一起组成访问虚拟路径
- 参数 :
- value : 用于指定请求的URL,它和path属性的作用是一样的
- method : 用于指定请求的方式
- params : 用于指定限制请求参数的条件,它支持简单的表达式,要求请求参数的key和value必须和配置的一模一样
- params = {“accountName”},表示请求参数必须有accountName
- params = {“money!100”},表示请求参数中money不能是100
- 视图解析器 :
<!--配置内部资源视图解析器-->
<bean id="viewResolver" class="org.springframework.web.servlet.view.InternalResourceViewResolver">
<!-- /jsp/success.jsp -->
<property name="prefix" value="/jsp/"></property>
<property name="suffix" value=".jsp"></property>
</bean>
web.xml的配置
<?xml version="1.0" encoding="UTF-8"?>
<web-app version="3.0" xmlns="http://java.sun.com/xml/ns/javaee"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd">
<!--配置SpringMVC的前端控制器-->
<servlet>
<servlet-name>DispatcherServlet</servlet-name>
<servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
<init-param>
<param-name>contextConfigLocation</param-name>
<param-value>classpath:spring-mvc.xml</param-value>
</init-param>
<load-on-startup>1</load-on-startup>
</servlet>
<servlet-mapping>
<servlet-name>DispatcherServlet</servlet-name>
<url-pattern>/</url-pattern>
</servlet-mapping>
<!--全局初始化参数-->
<context-param>
<param-name>contextConfigLocation</param-name>
<param-value>classpath:applicationContext.xml</param-value>
</context-param>
<!--配置监听器-->
<listener>
<listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
</listener>
<servlet>
<servlet-name>UserServlet</servlet-name>
<servlet-class>com.itheima.web.UserServlet</servlet-class>
</servlet>
<servlet-mapping>
<servlet-name>UserServlet</servlet-name>
<url-pattern>/userServlet</url-pattern>
</servlet-mapping>
</web-app>