初始Spring MVC:
Spring MVC属于SpringFrameWork的后续产品,已经融合在Spring Web Flow里面。Spring 框架提供了构建 Web 应用程序的全功能 MVC 模块。使用 Spring 可插入的 MVC 架构,从而在使用Spring进行WEB开发时,可以选择使用Spring的Spring MVC框架或集成其他MVC开发框架,如Struts1(现在一般不用),Struts 2(一般老项目使用)等。
MVC设计模式的任务是将包含业务数据的模块与显示模块的视图解耦。这是怎样发生的?在模型和视图之间引入重定向层可以解决问题。此重定向层是控制器,控制器将接收请求,执行更新模型的操作,然后通知视图关于模型更改的消息
Spring+MVC=SpringMVC : 在spring的基础上,对MVC思想的一个实现,是一个MVC框架
SpringMVC: 对servlet做的一个封装,换成controller层
相对于struts2,SpringMVC和Spring结合的更加完美
使用SpringMVC框架需要在原项目的基础上添加一个jar包spring-webmvc-4.1.0.RELEASE.jar(版本可能不同)
然后需要配置web.xml文件
<!-- SpringMVC入口 -->
<servlet>
<servlet-name>springMVC</servlet-name>
<!-- springmvc分发器 -->
<servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
<!-- 默认到WEB-INF下加载springmvc的配置文件 <<servlet-name>>-servlet.xml==>springMVC-servlet.xml -->
<!-- 指定位置下的springmvc配置文件 -->
<init-param>
<param-name>contextConfigLocation</param-name>
<param-value>classpath:com/gxy/config/springMVC-servlet.xml</param-value>
</init-param>
<!-- 配置一个大于等于0的数,在服务器启动的时候,实例化 -->
<load-on-startup>1</load-on-startup>
</servlet>
<servlet-mapping>
<!-- uri地址规则匹配 *.do -->
<servlet-name>springMVC</servlet-name>
<url-pattern>*.do</url-pattern>
</servlet-mapping>
使用URI规则匹配后只有在满足地址后缀 .do,才会进入SpringMVC框架
添加,配置SpringMVC的主配置文件 springmvc-servlet.xml
<!-- 开启注解扫描 -->
<context:component-scan base-package="com.rj182.controller"></context:component-scan>
<!-- mvc注解驱动,自动注册MVC依赖的内置bean -->
<mvc:annotation-driven></mvc:annotation-driven>
<!-- 视图解析器 -->
<bean class="org.springframework.web.servlet.view.InternalResourceViewResolver">
<property name="prefix" value="/"></property>
<property name="suffix" value=".jsp"></property>
</bean>
创建controller包,创建一个普通的类ClientController,添加对应注解
@Controller @Autowired @RequestMapping
由于使用规则匹配所以需要修改login.jsp 的登录跳转地址
原代码:
<form method="post" action="${pageContext.request.contextPath }/client/loginAction" id="form1">
现代码:
<form method="post" action="${pageContext.request.contextPath }/client/MVClogin.do" id="form1">
工作流程:
(1)首先浏览器发送请求——>DispatcherServlet,前端控制器收到请求后自己不进行处理,而是委托给其他的解析器进行处理,作为统一访问点,进行全局的流程控制;
(2)DispatcherServlet——>HandlerMapping,处理器映射器将会把请求映射为HandlerExecutionChain对象(包含一个Handler处理器对象、多个HandlerInterceptor拦截器)对象;
(3)DispatcherServlet——>HandlerAdapter,处理器适配器将会把处理器包装为适配器,从而支持多种类型的处理器,即适配器设计模式的应用,从而很容易支持很多类型的处理器;
(4)HandlerAdapter——>调用处理器相应功能处理方法,并返回一个ModelAndView对象(包含模型数据、逻辑视图名);
(5)ModelAndView对象(Model部分是业务对象返回的模型数据,View部分为逻辑视图名)——> ViewResolver, 视图解析器将把逻辑视图名解析为具体的View;
(6)View——>渲染,View会根据传进来的Model模型数据进行渲染,此处的Model实际是一个Map数据结构;
(7)返回控制权给DispatcherServlet,由DispatcherServlet返回响应给用户,到此一个流程结束。
参数收集方法有三种(均为转发):
- 内置对象 HttpServletRequest
@RequestMapping("/client/MVClogin")
public String login1(HttpServletRequest request) {
String username = request.getParameter("username");
String password = request.getParameter("password");
System.out.println("username is:"+username);
System.out.println("password is:"+password);
return "success";
}
- 方法参数收集(常用)前台的key值对应到参数值,就可以获取到value
@RequestMapping("/client/MVClogin")
public String login1(String username,String password) {
System.out.println("username is:"+username);
System.out.println("password is:"+password);
return "success";
}
- 方法对象收集(常用) 后台执行无参构造方法,创建对象 根据前台的key,调用对应的set/get方法完成赋值
@RequestMapping("/client/MVClogin")
public String login1(Client client) {
System.out.println("username is:"+client.getCliName());
System.out.println("password is:"+client.getCliPassword());
return "success";
}
SpringMVC乱码处理
在web.xml添加Spring过滤,处理所有请求地址,转译字符编码UTF-8
<!-- spring提供的字符编码过滤器 -->
<filter>
<filter-name>characterEncodingFilter</filter-name>
<filter-class>org.springframework.web.filter.CharacterEncodingFilter</filter-class>
<init-param>
<param-name>encoding</param-name>
<param-value>UTF-8</param-value>
</init-param>
<!-- 响应字符编码集 -->
<init-param>
<param-name>forceEncoding</param-name>
<param-value>true</param-value>
</init-param>
</filter>
<!-- 过滤所有地址请求 -->
<filter-mapping>
<filter-name>characterEncodingFilter</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>