Hello,今天给各位童鞋们分享Spring MVC,赶紧拿出小本子记下来吧!
1.1 三层架构
三层架构:
1.2 MVC
MVC(Model View Controller),一种用于设计创建web应用程序表现层的模式
Model(模型):数据模型,用户封装数据
View(视图):页面视图,用户展示数据
2.1 入门案例制作(重点)
步骤:
<dependencies>
<!--servlet3.1规范坐标-->
<dependency>
<groupId>javax.servlet</groupId>
<artifactId>javax.servlet-api</artifactId>
<version>3.1.0</version>
<scope>provided</scope>
</dependency>
<!--jsp坐标-->
<dependency>
<groupId>javax.servlet.jsp</groupId>
<artifactId>jsp-api</artifactId>
<version>2.1</version>
<scope>provided</scope>
</dependency>
<!--spring坐标-->
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-context</artifactId>
<version>5.1.9.RELEASE</version>
<scope>provided</scope>
</dependency>
<!--springmvc坐标-->
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-webmvc</artifactId>
<version>5.1.9.RELEASE</version>
<scope>provided</scope>
</dependency>
<!--spring web坐标-->
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-web</artifactId>
<version>5.1.9.RELEASE</version>
<scope>provided</scope>
</dependency>
</dependencies>
<!--构建-->
<build>
<!--设置插件-->
<plugins>
<!--具体的插件配置-->
<plugin>
<groupId>org.apache.tomcat.maven</groupId>
<artifactId>tomcat7-maven-plugin</artifactId>
<version>2.1</version>
<configuration>
<port>80</port>
<path>/</path>
</configuration>
</plugin>
</plugins>
</build>
2.定义业务层处理器Controller,并配置成spring的bean(等同于Servlet)
该bean的处理需要使用独立的配置文件扫描(XML版):spring-mvc.xml
3.web.xml中配置SpringMVC核心控制器,用于将请求转发到对应的具体业务处理器Controller中(等同于Servlet配置)
4.设定具体Controller的访问路径(等同于Servlet在web.xml中的配置),并设置返回页面
此处记录一个问题:
问题现象:org.apache.catalina.core.ContainerBase.addChildInternal ContainerBase.addChild: start: org.apache.catalina…
问题解决:
进入Project Structures(ctrl+shift+alt+S)–>点击左侧Project Settings下的Artifacts。
点击中间栏项目,这里会两个文件,一个是:项目名:war(war压缩包),一个是项目名:war exploded(war为压缩包)。
点击war exploded项目,在右侧中第一栏Output Layout(项目发布生成的文件)下,展开WEB-INF文件夹,此时该目录下只有classes目录,无lib目录,自己手动创建一个lib目录,并点击上面+选择Library File添加maven导入的jar包
重启tomcat就解决了(我是这样解决的,不保证所有类似问题都能解决)
2.2 入门案例工作流程分析(重点)
服务器启动:
加载web.xml中的DispatcherServlet
读取spring-mvc.xml中的配置,加载所有com.itheima包中所有标记为bean的类
读取bean中方法上标注@RequestMapping("/save")的内容
处理请求:
DispatcherServlet配置拦截所有请求 /
使用请求路径与所有加载的@RequestMapping的内容进行比对
执行对应的方法
根据方法的返回值在webapp目录中查找对应的页面并展示
2.3 SpringMVC技术架构图(重点)
SpringMVC技术架构图:
DispatcherServlet:前端控制器,是整体流程控制中心,由其调用其他组件处理用户的请求,有效的降低了组件间的耦合性
HandleMapping:处理器映射器,负责根据用户请求找到对应具体的Handler处理器
Handler:处理器,业务处理的核心类,通常由开发者编写,描述具体的业务
HandlerAdapter:处理器适配器,通过它对处理器进行执行
ViewResolver:视图解析器,将处理结果生成View视图
View:视图,最终产出结果,常用视图如jsp、html
3.1 Controller加载控制(重点)
SpringMVC的处理器对应bean必须按照规范格式开发,为避免加入无效的bean可通过bean加载过滤器进行包含设定或排除设定,表现层bean标注通常设为@Controller
<context:component-scan base-package="com.itheima">
<context:include-filter
type="annotation"
expression="org.springframework.stereotype.Controller"/>
</context:component-scan>
此处记录一个问题:
问题现象:启动tomcat完成时,idea弹窗提示“http://localhost:80/找不到应用程序”
解决方法:点击idea主界面运行图标旁下拉列表,选择Edit Configuration,进入配置界面,Open Browser选择一个固定浏览器,不要使用默认的浏览器(tomcat启动完成自动使用该浏览器访问)
制作案例:和前面案例一样,只需修改spring-mvc.xml配置文件:
<context:component-scan base-package="com.itheima">
<!--添加过滤,包含该注解才会被扫描到-->
<context:include-filter type="annotation" expression="org.springframework.stereotype.Controller"/>
</context:component-scan>
bean加载控制说明:
业务层与数据层bean加载由spring控制,参照spring课程加载方式
表现层bean加载由SpringMVC单独控制
表现层处理器bean使用注解@Controller声明
bean加载控制使用包含性过滤器
过滤器类型为通过注解进行过滤
过滤的注解名称为Controller
3.2 静态资源加载
核心控制器拦截的是所有请求,需要对非普通资源请求进行放行,通过配置放行资源实现
<mvc:resources mapping="/img/" location="/img/"/>
<mvc:resources mapping="/js/" location="/img/"/>
<mvc:resources mapping="/css/" location="/img/"/>
使用简化格式可以放行所有普通资源调用,无需一一枚举
<mvc:default-servlet-handler/>
还是之前案例内容,只需做如下修改:
注意:webapp下img目录需设置为resources目录,否则无法访问
3.3 中文乱码处理
SpringMVC提供专用的中文字符过滤器,用于处理乱码问题。在web.xml进行如下配置:
3.4 注解驱动
使用注解形式转化SpringMVC核心配置文件为配置类
@Configuration
@ComponentScan(value = "com.itheima",
excludeFilters = @ComponentScan.Filter(
type = FilterType.ANNOTATION,
classes = Controller.class)
)
public class SpringMvcConfiguration {
}
操作过程:
2. 基于servlet3.0规范,自定义servlet容器初始化配置类,加载SpringMVC核心配置类
3. 静态资源加载过滤(注解版)
配置类实现WebMvcConfigurer接口,覆盖addResourceHandlers方法,在其中对具体的资源进行设定
@Override
public void addResourceHandlers(ResourceHandlerRegistry registry) {
registry.addResourceHandler("/img/").addResourceLocations("/img/");
registry.addResourceHandler("/js/").addResourceLocations("/js/");
registry.addResourceHandler("/css/").addResourceLocations("/css/");
}
或者覆盖configureDefaultServletHandling方法,使用Servlet默认过滤规则
@Override
public void configureDefaultServletHandling(DefaultServletHandlerConfigurer configurer) {
configurer.enable();
}
4.中文乱码处理(注解版)
Servlet3.0规范启动服务器时做的工作通过实现ServletContainerInitializer接口,在onStartup方法中完成,包括监听器注册、过滤器注册等
4.1 请求参数(重点)
SpringMVC将传递的参数封装到处理器方法的形参中,达到快速访问参数的目的
访问URL:http://localhost/requestParam?name=itheima
@RequestMapping("/requestParam")
public String requestParam(String name) {
System.out.println("name = "+name);
return "page.jsp";
}
请求参数类型:
普通类型参数
参数设定
名称:@RequestParam
类型:形参注解
位置:处理器类中的方法形参前方
作用:绑定请求参数与对应处理方法形参间的关系
范例:
@RequestMapping("/requestParam2")
public String requestParam2(@RequestParam(value = "userName",required = true,defaultValue = "value") String name) {
System.out.println("name = "+name);
return "page.jsp";
}
注意:若设置了required = true,则在 浏览器URL地址栏必须加上参数,否则报错404。可以通过设置默认参数defaultValue = "value"避免未输入报错
访问路径:http://localhost/requestParam2?userName=zhangsan
POJO类型参数
注意:这里需要注释掉上面的方法requestParam2,否则此处也需要给参数添加注解@RequestParam,否则报错500:java.lang.IllegalArgumentException: Name for argument type [java.lang.String] not available, and par…
参数冲突
控制台打印结果:user = User{name=‘Jock’, age=30}, name = Jock
复杂POJO类型参数
public class Address {
private String province;
private String city;
private String address;
}
public class User {
private String name;
private Integer age;
private Address address;
}
@RequestMapping("/requestParam5")
public String requestParam5(User user) {
System.out.println("city = "+user.getAddress().getCity());
return "page.jsp";
}
控制台打印结果:user = User{name=‘null’, age=null, address=null, nick=[Jock1, Jock2, Jocker]}
@RequestMapping("/requestParam7")
public String requestParam7(User user) {
System.out.println("addresses = "+user.getAddresses());
return "page.jsp";
}
访问报错400:java.lang.IllegalArgumentException: 在请求目标中找到无效字符。有效字符在RFC 7230和RFC 3986中定义
百度解决方案:tomcat配置文件–>conf–>server.xml,修改内容
<Connector port="8080" protocol="HTTP/1.1" connectionTimeout="20000" redirectPort="8443" URIEncoding="utf-8"
relaxedPathChars="|{}[],%"
relaxedQueryChars="|{}[],%" />
然而,修改了还是报该错误
同样报错
数组类型参数
集合类型参数
4.2 类型转换器
SpringMVC对接收的数据进行自动类型转换,该工作通过Converter接口实现
标量转换器:
集合、数组相关转换器
默认转换器
控制台打印结果:date = Fri Apr 30 00:00:00 CST 2021
日期类型格式转换
日期类型格式转换(简化版)
@RequestMapping("/requestParam12")
public String requestParam12(@DateTimeFormat(pattern = "yyyy-MM-dd") Date date) {
System.out.println("date = "+date);
return "page.jsp";
}
@DateTimeFormat(pattern = "yyyy-MM-dd")
private Date birthday;
注意:依赖注解驱动支持
<mvc:annotation-driven />
自定义类型转换器
注册自定义转换器
4.3 请求映射(重点)
名称:@RequestMapping
类型:方法注解
位置:处理器类中方法定义上方
作用:绑定请求地址与对应处理方法间的关系
范例:
@RequestMapping("/requestURL")
public String requestParam12(@DateTimeFormat(pattern = "yyyy-MM-dd") Date date) {
System.out.println("date = "+date);
return "page.jsp";
}
@Controller
public class UserController {
@RequestMapping("/requestURL1")
public String requestURL1() {
System.out.println();
return "page.jsp";
}
}
访问root路径下的user路径下的页面
@Controller
@RequestMapping("/user")
public class UserController {
@RequestMapping("/requestURL2")
public String requestURL2() {
System.out.println();
return "/page.jsp";
}
}
@RequestMapping属性
5.1 无数据跳转页面
响应方式:(数据流)
页面跳转设定:
页面跳转方式:
@RequestMapping("/showPage1")
public String showPage1() {
System.out.println("user mvc controller is running...");
return "forward:page.jsp";
}
重定向
@RequestMapping("/showPage2")
public String showPage2() {
System.out.println("user mvc controller is running...");
return "redirect:page.jsp";
}
注意:页面访问地址所携带的/可以使用。但是在WEB-INF目录下的资源forward可以访问,而redirect不能访问。
页面访问快捷设定
<bean class="org.springframework.web.servlet.view.InternalResourceViewResolver">
<property name="prefix" value="/WEB-INF/page/"/>
<property name="suffix" value=".jsp"/>
</bean>
@RequestMapping("/showPage3")
public String showPage3() {
System.out.println("user mvc controller is running...");
return "page";
}
使用了简化配置,跳转页面名称前不能加forward,否则报错
@RequestMapping("/showPage4")
public String showPage4() {
System.out.println("user mvc controller is running...");
return "forward:page";//HTTP状态 404 - 未找到
}
页面访问快捷设定缺省页面:
@RequestMapping("/showPage5")
public void showPage5() {
}
等同于
@RequestMapping("/showPage5")
public String showPage5() {
return "showPage5";
}
5.2 带数据跳转页面(重点)
@RequestMapping("showPageAndData1")
public String showPageAndData1(HttpServletRequest request) {
request.setAttribute("name","itheima");
return "page";
}
方式二:使用Model类型形参进行数据传递
@RequestMapping("showPageAndData2")
public String showPageAndData2(Model model) {
model.addAttribute("name","Jock");
Book book = new Book();
book.setName("SpringMVC入门案例");
book.setPrice(66.66);
model.addAttribute(book);
return "page";
}
方式三:使用ModelAndView类型形参进行数据传递,将该对象作为返回字传递给调用者
重定向:
@RequestMapping("showPageAndData5")
public ModelAndView showPageAndData5(ModelAndView modelAndView) {
modelAndView.setViewName("redirect:page");//等同于return "redirect:page.jsp";
return modelAndView;
}
5.3 存数据返回(JSON)(重点)
导入json坐标pom.xml
运行tomcat可能会报错:rg.apache.catalina.core.StandardContext.filterStart 启动过滤器异常
java.lang.ClassNotFoundException: org.springframework.web.filter.CharacterEncodingFilter
解决方案:在上面讲过,Project Structures(ctrl+shift+alt+S)–> Project Settings下的Artifact --> swar exploded项目 --> Output Layout --> 展开WEB-INF–>手动创建一个lib目录(由于上面已经创建了,此处不再创建),并点击上面+选择Library File添加maven导入的jar包。重启tomcat就解决了
返回数据:
方式一:使用response对象完成数据返回
@RequestMapping("/showData1")
public void showData1(HttpServletResponse response) throws IOException {
response.getWriter().write("message");
}
方式二:(简化格式)
@RequestMapping("/showData2")
@ResponseBody
public String showData2() {
return "message";
}
返回JSON数据:
@RequestMapping("/showData2")
@ResponseBody
public String showData2() {
return "{'name':'Jock'}";
}
方式二(对象):使用SpringMVC提供的消息类型转换器将对象与集合数据自动转换为json数据
<mvc:annotation-driven/>
注解驱动格式
@Configuration
@ComponentScan("com.itheima")
public class SpringMVCConfiguration {
}
6.1 HttpServletRequest
SpringMVC提供访问原始Servlet接口API的功能,通过形参声明即可
打印结果:
org.apache.catalina.connector.RequestFacade@1f787c3e
org.apache.catalina.connector.ResponseFacade@45b7d257
org.apache.catalina.session.StandardSessionFacade@411f594e
6.2 HttpServletResponse
6.3 HttpSession
6.4 Head
Head数据获取:
名称:@RequestHeader
类型:形参注解
位置:处理器类中的方法形参前方
作用:绑定请求头数据与对应处理方法形参间的关系
范例:
打印结果:3AE4C46FC4AE80D62FAA29DA2DDD383F
6.5 Session
Session数据获取:
名称:@SessionAttribute
类型:形参注解
位置:处理器类中的方法形参前方
作用:绑定请求Session数据与对应处理方法形参间的关系
范例:
Session数据设置(了解):
6.6 注解式参数数据封装底层原理
好啦,今天的文章就到这里,希望能帮助到屏幕前迷茫的你们!
到此这篇spring教程电子书(spring教程 csdn)的文章就介绍到这了,更多相关内容请继续浏览下面的相关推荐文章,希望大家都能在编程的领域有一番成就!版权声明:
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若内容造成侵权、违法违规、事实不符,请将相关资料发送至xkadmin@xkablog.com进行投诉反馈,一经查实,立即处理!
转载请注明出处,原文链接:https://www.xkablog.com/rfx/17080.html