SpringMVC01之入门
1. 什么是springMVC?Spring Web MVC是一种基于Java的实现了MVC设计模式的、请求驱动类型的、轻量级Web框架。2. SpringMVC处理请求的流程2.1 工作原理:1. 首先用户发送请求-->DispatherServlet2. DispatcherServlet-->HandlerMapping3. DispatcherServlet-->HandlerAdapte
目录
5.2 SSM集成 5.2.1 在WEB-INF下添加springmvc-servlet.xml(spring-mvc.xml)
5.2.2 修改web.xml配置SpringMVC的核心控制器DispatcherServlet
附录一:在请求处理方法中添加@ResponseBody注解,将返回结果直接转换成JSON
前言:✨✨✨
接着往后的SpringMVC都是连接着上面的mybatis一起的,也就是我们所说的ssm框架,有兴趣的可以去看看前面的文章
1. 什么是springMVC?
Spring Web MVC是一种基于Java的实现了MVC设计模式的、请求驱动类型的、轻量级Web框架。
2. SpringMVC处理请求的流程
2.1 工作原理:
1. 首先用户发送请求-->DispatherServlet
2. DispatcherServlet-->HandlerMapping
3. DispatcherServlet-->HandlerAdapter
4. HandlerAdapter--> 执行处理器并返回ModelAndView
5. ModelAndView的逻辑视图名-->ViewResolver
6. View-->渲染
7. 返回控制权给DispatcherServlet,由DispatcherServlet返回呼应给用户,流程结束
2.2 请求流程(详解《SpringMVC工作原理图》)
1. 用户发送请求至前端控制器DispatcherServlet(中央控制器)
2. DispatcherServlet收到请求调用HandlerMapping(处理映射器)
3. 处理器映射器找到具体的处理器(可以根据xml配置、注解进行查找),生成处理器对象及处理器拦截器(如果有则生成)一并返回给DispatcherServlet
4. DispatcherServlet调用HandlerAdapter处理器适配器
5. HandlerAdapter经过适配调用具体的处理器(Controller,也叫后端控制器)
6. 由Controller执行完成返回ModelAndView
7. HandlerAdapter将controller执行结果ModelAndView返回给DispatcherServlet
8. DispatcherServlet将ModelAndView传递给ViewReslover视图解析器,请求视图解析
9. ViewReslover解析后返回具体View
10.DispatcherServlet根据View进行视图渲染(即将模型数据填充至视图中)
11.DispatcherServlet响应用户
3. SpringMVC核心开发步骤
3.1 DispatcherServlet在web.xml中的部署描述,从而拦截请求到springMVC
3.2 HandlerMapping的配置,从而将请求映射到处理器
3.3 HandlerAdapter的配置,从而支持多种类型的处理器
3.4 处理器(页面控制器)的配置,从而刊行功能处理
3.5 ViewResolver的配置,从而将逻辑视图名解析为具体的视图技术
4. SpringMVC的组件
4.1 前端控制器(DispatcherServlet):接收请求,响应结果,相当于转发器,中央处理器
4.2 请求到处理器映射(HandlerMapping):根据配置或者注解找到最终要执行的Handler
4.3 处理器适配器(HandlerAdapter):按照特定规则(HandlerAdapter要求的规则)去执行Handler
4.4 视图解析器(ViewResolver):进行视图解析,根据逻辑视图名解析成真正的视图(view)
4.5 处理器或页面控制器(Controller):执行具体的用户请求
4.6 验证器(Validator)
4.7 命令对象(Command 请求参数绑定到的对象就叫命令对象)
4.8 表单对象(Form Object提供给表单展示和提交到的对象就叫表单对象)
5. 如何在项目中添加springmvc
5.1 添加相关依赖
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-webmvc</artifactId>
<version>${spring.version}</version>
</dependency>
<!-- ********************** JSTL依赖 ********************** -->
<!-- 缺少下面的这两个jar包会报java.lang.NoClassDefFoundError: javax/servlet/jsp/jstl/core/Config-->
<!-- 原因:org.springframework.web.servlet.view.JstlView在视图解析时需要这二个jar包-->
<dependency>
<groupId>jstl</groupId>
<artifactId>jstl</artifactId>
<version>1.2</version>
</dependency>
<dependency>
<groupId>taglibs</groupId>
<artifactId>standard</artifactId>
<version>1.1.2</version>
</dependency>
5.2 SSM集成
5.2.1 在WEB-INF下添加springmvc-servlet.xml(spring-mvc.xml)
context:component-scan base-package="com.zking.ssm" use-default-filters="true">
<context:exclude-filter type="annotation" expression="org.springframework.stereotype.Controller"></context:exclude-filter>
</context:component-scan>
注1:修改application-mybatis的扫描配置
<context:component-scan base-package="com.zking.ssm" use-default-filters="false">
<context:include-filter type="annotation" expression="org.springframework.stereotype.Controller"/>
</context:component-scan>
注2:修改spring-mvc.xml的扫描配置
作用:放置重复扫描装配
5.2.2 修改web.xml配置SpringMVC的核心控制器DispatcherServlet
1) Spring与Web集成配置
2) 中文乱码过滤器
3) 配置SpringMVC核心控制器DispatcherServlet
5.3 第一个springMVC程序:HelloWorld
6. 常用注解
6.1 @Controller:用于标识处理器类
6.2 @RequestMapping:请求到处理器功能方法的映射规则,可定义到类和方法
常用参数:value、method
可将@RequestMapping标签定义到类名处窄化路径
6.3 @RequestParam:请求参数到处理器功能处理方法的方法参数上的绑定
常用参数:value、required、defaultValue
注:required设置成false的参数类型必须是引用类型,因为基本数据类型是不能为null的
6.4 @ModelAttribute:请求参数到命令对象的绑定
常用参数:value
6.4.1 可用@ModelAttribute标注方法参数,方法参数会被添加到Model对象中(作用:向视图层传数据)
6.4.2 可用@ModelAttribute标注一个非请求处理方法,此方法会在每次调用请求处理方法前被调用(作用:数据初始化)
6.4.3 可用@ModelAttribute标注方法,方法返回值会被添加到Model对象中(作用:向视图层传数据)
但此方法视图的逻辑图就会根据请求路径解析,例如:a/test42 --> /WEB-INF/a/test42.jsp
太麻烦几乎不用,不用直接保存到Model或ModelAndView中
6.5 @SessionAttributes:指定ModelMap中的哪些属性需要转存到session
常用参数:value、types
注1:必须放到class类名处
6.6 @InitBinder(本章暂不介绍):用于将请求参数转换到命令对象属性的对应类型
6.7 @RequestBody(重要~~~~~):用于目前比较流行的ajax开发的数据绑定(即提交数据的类型为json格式)
注1:使用@RequestBody注解的时候,前台的Content-Type必须要改为application/json,
如果没有更改,前台会报错415(Unsupported Media Type)。
后台日志就会报错Content type ‘application/x-www-form-urlencoded;charset=UTF-8’ not supported。
这些错误Eclipse下Tomcat是不会显示错误信息的,只有使用了日志才会显示
$.ajax({
url : "jsontest",
type : "POST",
async : true,
contentType : "application/json",
data : JSON.stringify(json),
dataType : 'json',
success : function(data) {
if (data.userstatus === "success") {
$("#errorMsg").remove();
} else {
if ($("#errorMsg").length <= 0) {
$("form[name=loginForm]").append(errorMsg);
}
}
}
});
其它
@CookieValue :cookie数据到处理器功能处理方法的方法参数上的绑定
@RequestHeader:请求头(header)数据到处理器功能处理方法的方法参数上的绑定
@RequestBody:请求的body体的绑定(通过HttpMessageConverter进行类型转换);
@ResponseBody:处理器功能处理方法的返回值作为响应体(通过HttpMessageConverter进行类型转换);
@ResponseStatus:定义处理器功能处理方法/异常处理器返回的状态码和原因;
@ExceptionHandler:注解式声明异常处理器;
@PathVariable:请求URI中的模板变量部分到处理器功能处理方法的方法参数上的绑定
7. 请求处理方法的参数及返回值
7.1请求处理方法的参数
ServletRequest/HttpServletRequest
HttpServletResponse/HttpServletResponse
HttpSession
RedirectAttributes
Model/ModelAndViewWebRequest/NativeWebRequest
Locale
InputStream/Reader
OutputStream/Writer
Principal
HttpEntiry<?>
Errors
BindingResult
SessionStatus
UriComponentsBuilder
带@PathVariable,@MatrixVariable注释的对象
@RequestParam,@RequestHeader,@RequestBody,@RequestPart
特别重要的是:org.springframework.ui.Model类型,每次调用请求处理方法时,SpringMVC都创建Model对象并将其注入到各种对象
7.2返回值的类型
ModelAndView
Model
String(代表一个逻辑视图名)void
Map
View
Callable
DeferredResult
其它任意类型,spring将其视作输出给View的对象模型
8. 页面跳转
8.1 转发:"forward:path"
8.2 重定向:"redirect:path"
注1:这两种跳转方式将会绕开视图解析器的前缀和后缀
注2:还有就是如果是在同一controller中则不用使用"/"从根目录开始,而如果是在不同的controller则一定要从根目录开始。
9. 访问其它的静态资源(被springmvc拦截了)
<mvc:resources location="/css/" mapping="/css/**"/>
<mvc:resources location="/images/" mapping="/images/**"/>
<mvc:resources location="/js/" mapping="/js/**"/>
<mvc:resources location="/static/" mapping="/static/**" cache-period="86400" />
SpringMVC会自动给静态资源Response添加缓存头Cache-Control和Expires值
🎉🎉🎉🎉🎉🎉🎉🎉🎉🎉🎉🎉🎉🎉🎉🎉🎉🎉
附录一:在请求处理方法中添加@ResponseBody注解,将返回结果直接转换成JSON
@RequestMapping("/loadFwxxToJson")
@ResponseBody
public Fwxx loadFwxxToJson(@ModelAttribute Fwxx fwxx) {
...
}
注:此请求处理方法返回的已经不是视图了
附录二:解决JSON死循环问题
@JsonIgnore
附录三:解决JSON格式化问题
JsonFormat
日期格式化
数字格式化(使用较少)
附录四:转换时指定属性名
@JsonProperty("error_code")
人生的不如意,对每个人的当下来说,都是最好的安排!!!
岁月为笔,相思为墨,字里行间全是你!!!
洁身自好,绝对理智,永远温柔,永远清醒!!!
以上就是今天的分享,感谢你的观赏!!!
更多推荐
所有评论(0)