一、概述
SpringMVC已经成为目前最主流的MVC框架之一,并随着Spring3.0的发布,全面超越Struts2,成为最优秀的MVC框架。它通过一套注解,让一个简单的Java类称为处理请求的控制器,而无需实现任何接口。同时他还支持RESTful编程风格的请求
二、SpringMVC快速入门
需求:客户端发起请求,服务器端接受请求,执行逻辑并进行视图跳转
开发步骤:
1、导入SpringMVC相关坐标
2、配置SpringMVC核心控制器DispathcerServlet
3、创建Controller类和视图页面
4、使用注解配置Controller类中业务方法的映射地址
5、配置SpringMVC核心文件spring-mvc.xml
6、客户端发起请求测试
三、详细步骤
1、导入相关坐标
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-context</artifactId>
<version>5.0.5.RELEASE</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-web</artifactId>
<version>5.0.5.RELEASE</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-webmvc</artifactId>
<version>5.0.5.RELEASE</version>
</dependency>
2、创建applicationContext.xml和spring-mvc.xml核心配置文件
<!--自动扫描包-->
<context:component-scan base-package="com"/>
<!--开放静态资源访问-->
<mvc:default-servlet-handler />
<!--mvc注解驱动-->
<mvc:annotation-driven />
3、配置web.xml,创建项目时,自动加载applicationContext.xml和spring-mvc.xml配置文件
<!--spring-->
<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>
<!--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>
4、创建control.java测试
类上加注解@Control
类上或方法上加@RequestMapping("/XXX") //类上是浏览器父级映射路径 方法上是子级映射路径
方法返回值为String return "redirect:/index.jsp"; //但不局限于String ,下文分析 返回有两种方法 forword redirect
四、语法碎解
1、<!--配置内部视图资源解析器--> //程序封装对象后,返回视图层
<bean class="org.springframework.web.servlet.view.InternalResourceViewResolver">
<property name="prefix" value="/jsp/"></property> //前缀名
<property name="suffix" value=".jsp"></property> //后缀名
</bean>
2、<!--开放静态资源访问权限-->
<!--<mvc:resources mapping="/js/**" location="/js/" />-->
<mvc:default-servlet-handler />
3、配置自定义类型转换,springmvc能够将简单的类型进行自动类型转换,但是不能处理复杂的。如:日期,
<!--声明转换器-->
<bean id="conversionService" class="org.springframework.context.support.ConversionServiceFactoryBean">
<property name="converters">
<list>
<bean class="mvc.controller.myConverter"></bean> //自定义类型转换类相对路径
</list>
</property>
</bean>
<!--配置springMVC驱动,自动封装对象为json格式-->
<mvc:annotation-driven conversion-service="conversionService"/>
注:自定义类型转换类需要实现Converter<String,Date>接口(org.springframework.core.convert.converter)
4、@ResponseBody //加在方法上,告诉springMVC框架 不进行视图跳转 直接进行数据响应
springmvc返回封装的对象,里面可以设置返回的对象(addObject(String,Object))和返回的路径(setViewName("XX"))
ModelAndView modelAndView = new ModelAndView();
5、返回对象或集合或json类型
<!--配置处理器映射器-->
<!--<bean class="org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter">
<property name="messageConverters">
<list>
<bean class="org.springframework.http.converter.json.MappingJackson2HttpMessageConverter" />
</list>
</property>
</bean>-->
上面的可以使用注解驱动代替,因为注解驱动里帮我们配好了
<mvc:annotation-driven />
附加:<!--jackSon-->
<dependency>
<groupId>com.fasterxml.jackson.core</groupId>
<artifactId>jackson-core</artifactId>
<version>2.9.0</version>
</dependency>
<dependency>
<groupId>com.fasterxml.jackson.core</groupId>
<artifactId>jackson-databind</artifactId>
<version>2.9.0</version>
</dependency>
<dependency>
<groupId>com.fasterxml.jackson.core</groupId>
<artifactId>jackson-annotations</artifactId>
<version>2.9.0</version>
</dependency>
6、接受浏览器参数类型碎解
1)接受数组类型参数 //方法参数上加注解。如:save (@RequestBody List<User> list)
2)control参数与表单参数不一致,需要加注解。如:save6(@RequestParam("name") String username)
3)初始restFul风格:a)方法上加@RequestMapping(value = "/save7/{name}")
b)方法参数上加注解。如:@PathVariable("name") String username
4)获取请求头: 方法参数上加注解。如:save9(@RequestHeader("User-Agent") String str)
5)获取cookie: 方法参数上加注解。如:save10(@CookieValue("JSESSIONID") String str)
7、解决请求参数乱码问题,web.xml要加一个过滤器,自动转码
<!--解决乱码问题-->
<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>
</filter>
<filter-mapping>
<filter-name>CharacterEncodingFilter</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
8、springMVC文件上传
1)文件上传客户端三要素
表单type="file"
表单的提交方式post
表单的enctype属性是多部分表单形式,及enctype="multipart/form-data"
2)导入坐标
<!--文件上传-->
<dependency>
<groupId>commons-fileupload</groupId>
<artifactId>commons-fileupload</artifactId>
<version>1.3.1</version>
</dependency>
<dependency>
<groupId>commons-io</groupId>
<artifactId>commons-io</artifactId>
<version>2.3</version>
</dependency>
3)<!--配置文件上传解析器-->
<bean id="multipartResolver" class="org.springframework.web.multipart.commons.CommonsMultipartResolver">
<property name="defaultEncoding" value="UTF-8"/>
<property name="maxUploadSize" value="500000"/>
</bean>
4)Control层,操作MultipartFile文件对象
String originalFilename = multipartFile.getOriginalFilename();
multipartFile.transferTo(new File("C:\\upload\\"+originalFilename));
9、拦截器HandlerInterceptor
1)自定义拦截器需实现HandlerInterceptor接口
2)<!--配置拦截器HandlerInterceptor-->
<mvc:interceptors>
<mvc:interceptor>
<mvc:mapping path="/**"/>
<bean class="mvcUpload.myHandlerInterceptor" />
</mvc:interceptor>
</mvc:interceptors>
10、spring异常处理
<!--配置简单异常-->
<!--<bean class="org.springframework.web.servlet.handler.SimpleMappingExceptionResolver">
<!–<property name="defaultErrorView" value="error" />–>
<property name="exceptionMappings" >
<map>
<entry key="java.lang.NumberFormatException" value="error1" />
<entry key="mvcUpload.myException" value="error3" />
</map>
</property>
</bean>-->
配置自定义异常需实现HandlerExceptionResolver接口
if(ex instanceof ArithmeticException){ //判断参数ex是否为除0异常,除0异常也可改为myException自定义异常
modelAndView.addObject("msg","自定义异常");
modelAndView.setViewName("error");
return modelAndView;
}
11、定时器task
schema上加入task标签
<!--定时器-->
<!--<task:scheduled-tasks>
<task:scheduled ref="myController" method="task" cron="0/5 * * * * ?"/> //ref:类对象 method:类方法 cron:定时参数
</task:scheduled-tasks>-->
注解方式:
先 配置task注解驱动:<task:annotation-driven />
方法上加注解: @Scheduled(cron = "0/5 * * * * ?")