一、概述
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 * * * * ?")
