深入学习SpringMVC以及学习总结

一、优点:

1.SpringMVC简化web程序开发;

2.SpringMVC效率很好(单例模式);

3.SpringMVC提供了大量扩展点,方便程序员自定义功能;

 

如果想学习Java工程化、高性能及分布式、深入浅出。微服务、Spring,MyBatis,Netty源码分析的朋友可以加我的Java高级交流:854630135,群里有阿里大牛直播讲解技术,以及Java大型互联网技术的视频免费分享给大家。

①.DispatcherServlet:核心控制器(springMVC的心脏)中转作用;

②.HandlerMapping:映射处理器(处理请求,找到对应的Handler);

③.HandlerAdapter:处理器适配,(Handler实现有两种方法,所以必须适配时候才能运行);

④.Handler:(Controller层):处理器

⑤.ViewResolver:视图解析器 通过视图的名称,解析具体的视图对象(jsp文件);

⑥.View:具体的视图技术进行渲染;

二、使用SpringMVC

 
添加依赖 IOC+AOP <dependency> <groupId>org.springframework</groupId> <artifactId>spring-webmvc</artifactId> <version>${spring.version}</version>此处版本可以根据需要选择 </dependency> 配置 1.配置核心控制器 (web.xml) <!--1.核心控制器--> <servlet> <servlet-name>springMVC</servlet-name> <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class> <load-on-startup>1</load-on-startup> </servlet> <servlet-mapping> <servlet-name>springMVC</servlet-name> <!--包含静态资源,也需要拦截 *.do、*.action拦截不到静态资源--> <url-pattern>/</url-pattern> </servlet-mapping> 2. springMVC的配置文件 默认在WEB-INF/servlet名称-servlet.xml springMVC-servlet.xml <!--2.配置HandlerMapping--> <bean class="org.springframework.web.servlet.handler.BeanNameUrlHandlerMapping"/> <!--3.配置HandlerAdapter--> <bean class="org.springframework.web.servlet.mvc.SimpleControllerHandlerAdapter"/> <!--4.配置Handler--> <bean name="/hello" class="org.itany.controller.HelloController"/> <!--5.视图解析器--> <bean class="org.springframework.web.servlet.view.InternalResourceViewResolver"> <property name="prefix" value="/WEB-INF/view/"/> <property name="suffix" value=".jsp"/> <!--6.使用具体的视图技术渲染--> <property name="viewClass" value="org.springframework.web.servlet.view.JstlView"/> </bean> 

三、基于注解方式使用SpringMVC

如果想学习Java工程化、高性能及分布式、深入浅出。微服务、Spring,MyBatis,Netty源码分析的朋友可以加我的Java高级交流:854630135,群里有阿里大牛直播讲解技术,以及Java大型互联网技术的视频免费分享给大家。

 
1.添加依赖 IOC+AOP <dependency> <groupId>org.springframework</groupId> <artifactId>spring-webmvc</artifactId> <version>${spring.version}</version>此处版本可以根据需要选择 </dependency> 2.配置DispatcherServlet 1.配置核心控制器 (web.xml) <!--1.核心控制器--> <servlet> <servlet-name>springMVC</servlet-name> <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class> <load-on-startup>1</load-on-startup> </servlet> <servlet-mapping> <servlet-name>springMVC</servlet-name> <!--包含静态资源,也需要拦截 *.do、*.action拦截不到静态资源--> <url-pattern>/</url-pattern> </servlet-mapping> 3.SpringMVC的配置文件(自定义配置文件) 需要在servlet中添加一个参数 <!--自定义springMVC的配置文件--> <init-param> <param-name>contextConfigLocation</param-name> <param-value>classpath:spring-mvc.xml</param-value> </init-param> <!--2 配置HandlerMapping--> <bean class="org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerMapping"/> <!--3 配置HandlerAdapter--> <bean class="org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter"/> <!--4 配置Handler--> <context:component-scan base-package="org.itany.controller"/> <!--5 配置视图解析器--> <bean class="org.springframework.web.servlet.view.InternalResourceViewResolver"> <property name="prefix" value="/WEB-INF/view/"></property> <property name="suffix" value=".jsp"/> <!--6 视图渲染技术--> <property name="viewClass" value="org.springframework.web.servlet.view.JstlView"/> </bean> 以上配置中:可以采用 <mvc:annotation-driver/>替代我们的第2、3步配置 

四、静态资源配置

1.如果DispatcherServlet配置了url-pattern '/' ,那么静态资源放在webapp下也访问不到,DispatcherServlet覆盖了Tomcat提供的用于访问静态资源的servlet(DefaultServlet);

可以用<mvc:default-servlet-handler/>去打开静态资源访问方式;

①.只能访问webapp下的静态资源;

②.和tomcat耦合(和服务器耦合);

2.springMVC提供静态资源访问:

<mvc:resources mapping="页面静态资源的映射" location="静态资源的目录路径"/>

五、直接跳转页面

<mvc:view-controller path="/showRegister" view-name="register"/>

等同于:

 
@RequestMapping("/showRegister") public String showRegister(){ return "register"; } 

六、常用注解

 
@Controller //将一个类映射为Controller层 @RestController //将一个类映射为Controller层(方法返回的都是数据模型) @RequestMapping //将一个方法映射到URL上 @GetMapping //将一个方法映射到URL上(只能为Get请求) @PostMapping //将一个方法映射到URL上(只能为Post请求) @RequestParam //将请求参数封装到方法参数上 @RequestHeader //将请求头部封装到方法参数上 @CookieValue //将Cookie封装到方法参数上 @PathVariable //将URL中的值封装到方法参数上 @RequestBody //将请求体(POST请求)中的值封装到方法参数上 @ModelAttrubite //将请求参数封装为对象(在请求作用域中,参数和方法级别) @SessionAttributes//将请求参数封装为对象(在Session作用域中,类级别) @Valid //后台校验 @InitBinder //(Spring2.5及之前版本会使用) @ResponseBody //将方法返回值写入到ResponseBody中 @ExceptionHandler //同一异常处理  @ControllerAdvice //Controller的通知 

七、Controller层方法的写法

如果想学习Java工程化、高性能及分布式、深入浅出。微服务、Spring,MyBatis,Netty源码分析的朋友可以加我的Java高级交流:854630135,群里有阿里大牛直播讲解技术,以及Java大型互联网技术的视频免费分享给大家。

 
1.方法的返回值 ModelAndView 模型和视图 String 视图 字符串 -->视图名 forward:url -->转发 redirect:url -->重定向 void 视图(用于请求url为视图名称) Object 模型 2.URL的写法 @RequestMapping() 可以添加在类上-->表示包的概念,访问这个类下的所有的方法都需要添加一个前缀 1.直接写URL 如@RequestMapping("/m1") 2.ant风格 * 单层路径 ** 多层路径 ? 单个字符 3.rest风格 {name} {name:正则表达式} @RequestMapping(path={"/url1","/url2"}) @RequestMapping(path="/url",method=RequestMethod.POST) //method指定请求方式 @RequestMapping(path="/url",params={"name"}) //表示该请求必须带一个name的参数  @RequestMapping(path="/url",headers={"User-Agent"}) //表示该请求必须带一个头部信息User-Agent(浏览器信息) 

八、Controller层方法参数

 
* 1.JAVA EE主键 HttpServletRequest/HttpServletResponse HttpSession 2. IO流 InputStream OutputStream Reader Writer 3. Spring组件 SessionStatus WebRequest NativeWebRequest *4.自定义类型 如User (请求参数中的key需要和对象中的setter方法一致) *5.获取错误信息 Errors/BindingResult *6.用于传递数据 Model Map ModelMap *7.基本类型和字符串类型 默认来源请求参数 (@RequestParam) 如果想要参数来源于请求头部 可以使用@RequestHeader 如果想要参数来源于cookie 可以使用@CookieValue 如果想要参数来源于URL 可以使用注解@PathVariable 如果想要参数来源于请求体 可以使用注解@RequestBody 

九、数据转换

 
方案一:spring2.5及之前版本使用 1.需要在Controller添加一个方法,方法采用@InitBinder 2.这个方法需要一个参数DataBinder 3.DataBinder.registerCustomEditor(Class<?> clazz,PropertyEditor propEditor>) 方案二:(只能做字符串到其他类型的转换) Formatter 1.实现接口Formtter 2.注册到IOC容器中 - 管理系统中formatter <!--用来管理自定义的formatter和converter--> <bean id="conversionService" class="org.springframework.format.support.FormattingConversionServiceFactoryBean"> <property name="formatters"> <set> <bean class="org.itany.formatter.String2DateFormatter"> <constructor-arg value="yyyy-mm-dd"></constructor-arg> </bean> </set> </property> </bean> - 将该coversion交个springMVC使用 <mvc:annotation-driven conversion-service="conversionService"/> 方法三:(能做任意类型到其他类型的转换) Converter 1.实现接口Converter 2.注册到IOC容器中 

十、统一异常处理

如果想学习Java工程化、高性能及分布式、深入浅出。微服务、Spring,MyBatis,Netty源码分析的朋友可以加我的Java高级交流:854630135,群里有阿里大牛直播讲解技术,以及Java大型互联网技术的视频免费分享给大家。

 
1.编写一个类 编写方法 @ExceptionHandler(Exception.class) public String exception(Exception ex){ return "500"; } 2.这个类上添加一个@ControllerAdvice 

十一、方法返回json以及xml数据格式

 
1.方法的返回值为Object,方法需要注解@ResponseBody 2.需要添加一个方法返回值的转换器(使用的是jackson) <mvc:annotation-driven conversion-service="conversionService"> <!--消息转换器 告诉springMVC我们方法返回值返回什么格式--> <mvc:message-converters> <bean class="org.springframework.http.converter.json.MappingJackson2HttpMessageConverter"/> </mvc:message-converters> </mvc:annotation-driven> 3.提供json处理包 <dependency> <groupId>com.fasterxml.jackson.core</groupId> <artifactId>jackson-core</artifactId> </dependency> <dependency> <groupId>com.fasterxml.jackson.core</groupId> <artifactId>jackson-databind</artifactId> </dependency> 使用gson 1.将消息转换器换为 <bean class="org.springframework.http.converter.json.GsonHttpMessageConverter"/> 2.将json处理的依赖修改为 <dependency> <groupId>com.google.code.gson</groupId> <artifactId>gson</artifactId> </dependency> 使用fastjson 1.将消息转换器换为 <bean class="com.alibaba.fastjson.support.spring.FastJsonHttpMessageConverter4"/> 2.将json处理的依赖包 <dependency> <groupId>com.alibaba</groupId> <artifactId>fastjson</artifactId> </dependency> 如果想要返回为xml 1.方法返回Object,需要注解@ResponseBody 还需要在@RequestMapping(produces="application/xml") 2.需要添加消息转换器(这个转换需要在json转换器的前面) <class="org.springframework.http.converter.xml.Jaxb2RootElementHttpMessageConverter"/> 3.需要添加一个依赖 <dependency> <groupId>org.springframework</groupId> <artifactId>spring-oxm</artifactId> </dependency> 注意:如果配置了json转换器,这个时候以前返回为String的方法,返回的时候会默认添加一对引号。 可以在消息转换器中添加一个字符串的转换器(这个转换需要在json转换器的前面) <bean class="org.springframework.http.converter.StringHttpMessageConverter"/> 

十二、自定义消息转换器

 
1.继承抽象类AbstractHttpMessageConverter 2.将消息转换器配置到SpringMVC中 <mvc:annotation-driver> <mvc:message-converters> <bean class="自定义的消息转换器"/> </mvc:message-converters> </mvc:annotation-driver> 

十三、拦截器

 
1.实现接口 HandlerInterceptor/WebRequestInterceptor preHandler 在handler方法之前调用 返回值表示true,不拦截 false, 拦截(不进入handler方法) postHandler 在handler方法之后调用 afterCompleition 在handler方法完成之后 2.配置 在mvc的配置文件中 1.表示拦截系统中所有的请求 <mvc:interceptors> <bean class="拦截器"/> </mvc:interceptors> 2.只需要拦截某些URL <mvc:interceptors> <mvc:interceptor> <mvc:mapping path="/url/**"/> <bean class="org.itany.interceptors.ControllerInterceptor"/> </mvc:interceptor> </mvc:interceptors> 3.排除一些url <mvc:interceptors> <mvc:interceptor> <mvc:mapping path="/**"/> <mvc:exclude-mapping path="/url/**"/> <bean class="org.itany.interceptors.ControllerInterceptor"/> </mvc:interceptor> </mvc:interceptors> 

十四、文件上传下载

 
1.jsp需要二进制提交 enctype="multipart/form-data" 2.Controller方法需要参数接收,参数的类型CommonsMultipartFile 3.需要文件上传的解析器 <!--文件上传--> <bean id="multipartResolver" class="org.springframework.web.multipart.commons.CommonsMultipartResolver"> <property name="maxUploadSize" value="10000000000"/> <property name="defaultEncoding" value="UTF-8"/> </bean> 4.需要添加依赖commons-fileupload <dependency> <groupId>commons-fileupload</groupId> <artifactId>commons-fileupload</artifactId> </dependency> 文件下载 PS:只要mvc最后url是带后缀的,SpringMVC会将其截取掉。 //告诉浏览器拿到资源不要打开,下载 response.addHeader("Content-Disposition","attachment;filename="+fileName); 

如果想学习Java工程化、高性能及分布式、深入浅出。微服务、Spring,MyBatis,Netty源码分析的朋友可以加我的Java高级交流:854630135,群里有阿里大牛直播讲解技术,以及Java大型互联网技术的视频免费分享给大家。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值