springMVC的学习
初学Spring MVC 可以按这个案例,敲大致能够掌握常用Spring MVC的内容,动手实践永远比单纯的看来的深刻.动手实践,实践出真知!
1.简介
-
MVC是一种架构模式
-
MVC分别指的是Model 模型层,View 视图层和Controller 控制器
-
Spring MVC的核心Controller控制器,可以用来分发请求和响应
-
Spring MVC基于Spring IOC容器运行,所有对象被IOC管理
2.IDEA环境下进行配置
1.创建Maven工程
- 构建webapp,让Maven对Web应用提供支持
- 配置Tomcat,进行Web功能的测试
2.环境配置
1.添加依赖
<!-- SpringMvc支持底层包 -->
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-webmvc</artifactId>
<version>5.2.1.RELEASE</version>
</dependency>
2.web.xml中进行配置
-
主要配置DispatcherServlet
-
DispatcherServlet作用:对所有请求进行拦截
<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns="http://xmlns.jcp.org/xml/ns/javaee"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/javaee http://xmlns.jcp.org/xml/ns/javaee/web-app_3_1.xsd"
version="3.1">
<!--DispatchServlet拦截所有请求-->
<servlet>
<servlet-name>springmvc</servlet-name>
<!--
DispatcherServlet是Spring MVC最核心的对象
DispatcherServlet用于拦截Http请求,
并根据请求的URL调用与之对应的Controller方法,来完成Http请求的处理
-->
<servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class>
<!--applicationContext.xml-->
<init-param>
<param-name>contextConfigLocation</param-name>
<param-value>classpath:applicationContext.xml</param-value>
</init-param>
<!--
在Web应用启动时自动创建Spring IOC容器,
并初始化DispatcherServlet
-->
<load-on-startup>0</load-on-startup>
</servlet>
<servlet-mapping>
<servlet-name>springmvc</servlet-name>
<!--"/" 代表拦截所有请求-->
<url-pattern>/</url-pattern>
</servlet-mapping>
</web-app>
3.创建配置文件
- resources目录下:applicationContext.xml
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:mvc="http://www.springframework.org/schema/mvc"
xmlns:context="http://www.springframework.org/schema/context"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:mv="http://www.springframework.org/schema/mvc"
xsi:schemaLocation="http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans.xsd
http://www.springframework.org/schema/context
http://www.springframework.org/schema/context/spring-context.xsd
http://www.springframework.org/schema/mvc
http://www.springframework.org/schema/mvc/spring-mvc.xsd">
<!--
context:component-scan 标签作用
在Spring IOC初始化过程中,自动创建并管理springmvc及子包中
拥有以下注解的对象.
@Repository
@Service
@Controller
@Component
-->
<context:component-scan base-package="springmvc"></context:component-scan>
<!--启用Spring MVC的注解开发模式-->
<mvc:annotation-driven/>
<!-- 将图片/JS/CSS等静态资源排除在外,可提高执行效率 -->
<mvc:default-servlet-handler/>
</beans>
4.开发Controller控制器
- 对应配置文件下制定扫描的包进行文件的创建或指定。
package springmvc.controller;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.ResponseBody;
@Controller
public class SpringMvcTest {
@GetMapping("/t")//通过GET方式发送对应的请求
@ResponseBody //直接进行响应,不进行页面的跳转
public String test(){
return "大哥大哥你好呀!";
}
}
5.进行发布测试
注意:记得对依赖进行发布!
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-uNM0IRD8-1632922817836)(C:\Users\Administrator\AppData\Roaming\Typora\typora-user-images\image-20210929102353584.png)]
-
运行测试用的控制器
-
重启Tomcat,测试
-
运行原理:
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-ZLuddh7O-1632922817875)(C:\Users\Administrator\AppData\Roaming\Typora\typora-user-images\image-20210929111412468.png)]
3.数据绑定
1.URL绑定
-
@GetMapping:绑定get请求
-
@PostMapping:绑定post请求
-
@RequestMapping:
通用型注解,既可以放到类上,也可以放到方法上:
(1)绑定在类上,指定前缀
(2)绑定在方法上,不区分post与get请求
@ResponseBody :直接进行响应在当前页面,不进行页面的跳转
2.接收请求参数
- controller方法接收请求参数
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-r5JRitNU-1632922817877)(C:\Users\Administrator\AppData\Roaming\Typora\typora-user-images\image-20210929112632186.png)]
这种方法可以进行类型的强制转换,在方法参数中进行书写。
@RequestParam:写在方法参数里,指定参数名与java参数名进行对应。
- 接收Java bean对象的请求参数
(1)创建实体类
实体类和传入的数据的名称要一样,数据类型要一样。
(2)将实体类中参数换成对象类型
适用于表单项比较多的情况。
3.URI绝对路径和相对路径
- 以“/”开头的为绝对路径,从当前目录进行查找
- 以“./”开头的为相对路径,从应用程序上下文路径开始寻找
4.处理复合的表单数据
-
利用数组
-
利用集合
复合数据需要用@RequestParam进行指定
-
利用实体类(在实体类中构建集合)
实体类需要与传入的请求数据保持一致
注意:如果利用MAP接收复合数据会丢失,只能接收单个数据。
-
构建关联对象
关联对象需要实例化,调用时要加上前缀
5.日期类型转换
- 单个参数的情况:
在Date参数前加上@DateTimeFormat(pattern = “yyyy-MM-dd”)
- 在实体类中
在Date属性上@DateTimeFormat(pattern = “yyyy-MM-dd”)
-
开发日期转换器类
(1)创建转换类
package springmvc.converter;
import org.springframework.core.convert.converter.Converter;
import java.text.ParseException;
import java.text.SimpleDateFormat;
import java.util.Date;
/**
* 时间格式转化器类
* 转换的是日期型
*/
public class DateConverter implements Converter<String, Date> {
public Date convert(String s) {
SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd");
try {
Date d = sdf.parse(s);
return d;
} catch (ParseException e) {
return null;
}
}
}
(2)在applicationContext.xml中进行配置
配置bean
<!--注册时间格式转化器类-->
<bean id="conversionService" class="org.springframework.format.support.FormattingConversionServiceFactoryBean">
<property name="converters">
<set>
<bean class="springmvc.converter.DateConverter"></bean>
</set>
</property>
</bean>
这一栏进行配置,遇到Date类型的会进行自动转换
<mvc:annotation-driven conversion-service="conversionService"/>
注意:
注解和转换器类进行日期格式的转换只能二者选其一,两者皆有的话会默认使用全局的转换器类进行转换!
4.解决中文乱码的问题
1.Web应用中产生原因:
- Tomcat默认字符集为西欧字符集
2.中文乱码解决配置
- GET请求乱码 -server.xml增加URIEncoding属性
(1)进入Tomacat文件conf目录下的server.xml进行编辑
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-psukyniu-1632922817880)(C:\Users\Administrator\AppData\Roaming\Typora\typora-user-images\image-20210929125728125.png)]
(2)找到对应地方,添加URIEncoding=“UTF-8”
<Connector connectionTimeout="20000" port="8080" protocol="HTTP/1.1" redirectPort="8443" URIEncoding="UTF-8"/>
注意:在Tomcat 8 以后的版本可以省略,默认会使用UTF-8编码
- POST请求乱码 - web.xml配置CharacterEncodingFilter
<filter>
<filter-name>characterFilter</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>characterFilter</filter-name>
<url-pattern>/</url-pattern>
</filter-mapping>
-
Rsponse响应乱码 - Spring配置StringHttpMessageConverter
applicationContext.xml中
<mvc:annotation-driven conversion-service="conversionService">
<!--设置响应时中文乱码问题-->
<mvc:message-converters>
<bean class="org.springframework.http.converter.StringHttpMessageConverter">
<property name="supportedMediaTypes">
<list>
<value>text/html;charset=utf-8</value>
</list>
</property>
</bean>
</mvc:message-converters>
5.响应输出结果
1. 利用@ResponseBody
- 直接产生响应体数据,不涉及任何视图
- 可以传输标准字符串/JSON/XML等格式数据
- 被StringHttpMessageConverter所影响
- 在返回值中书写,比较麻烦
- 例:
@Controller
public class SpringMvcTest {
@GetMapping("/t")//通过GET方式发送对应的请求
@ResponseBody //直接进行响应,不进行页面的跳转
public String test(){
return "大哥大哥你好呀!";
}
}
2.利用ModelAndView对象
- ModelAndView对象是指模型(数据)与视图(界面)对象
- 可以将包含数据对象与模板引擎进行绑定
- SpringMvc中默认的View是JSP,也可以配置其他的模板引擎
@GetMapping("/m")
public ModelAndView show(String id){
ModelAndView mav = new ModelAndView("/test.jsp");
mav.addObject("a",id);
return mav;
}
支持JSP页面的跳转和EM表达式
<html>
<head>
<title>Title</title>
</head>
<body>
<h1>
${a}
</h1>
</body>
</html>
注意,只能支持JSP,编程HTML就不行了
3.利用String+modelMap
/**
* String与ModelMap
* 1.有@ResponseBody,直接响应字符串本身
* 2.无 @ResponseBody,则由SpringMVC处理String指代的视图
* @param id 传入参数
* @param modelMap 视图集合
* @return contraller会根据返回String的情况
*/
@GetMapping("/s")
// @ResponseBody
public String showView1(String id , ModelMap modelMap){
String view = "/test.jsp";
return view;
}
3.ModelAndView核心用法
- addObject()方法设置的属性是默认存放在当前请求中的
- ModelAndView底层使用的是请求转发机制
- 重定向需要在跳转页面前加上"redirect:"
ModelAndView mav = new ModelAndView("redirect:/test.jsp");
- setViewName("/view.jsp")等同于在构造函数中创建跳转页面
注意:尽量使用绝对路径“/”以减少对外部的依赖。
6.利用SpringMVC整合FreeMarker
1.引入依赖
<!--模板引擎Freemark-->
<dependency>
<groupId>org.freemarker</groupId>
<artifactId>freemarker</artifactId>
<version>2.3.29</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-context-support</artifactId>
<version>5.1.9.RELEASE</version>
</dependency>
注意:spring-context-support要与spring-webmvc的版本保持一致,否则有些功能无法兼容!
2.启用Freemarker模板引擎
- 在application.xml中进行配置
<!--启用FreeMarker模板引擎-->
<bean id="ViewResolver" class="org.springframework.web.servlet.view.freemarker.FreeMarkerViewResolver">
<property name="contentType" value="text/html;charset=utf-8"/>
<property name="suffix" value=".ftl"/>
</bean>
<bean id="freemarkerConfig" class="org.springframework.web.servlet.view.freemarker.FreeMarkerConfigurer">
<property name="templateLoaderPath" value="/WEB-INF/ftl"/>
<property name="freemarkerSettings">
<props>
<prop key="defaultEncoding">UTF-8</prop>
</props>
</property>
</bean>
3.进行测试
- 模板文件只能放在指定设置文件下
(1)模板文件要为.ftl结尾的。
-
在跳转页面的url中可以省略后缀.jsp
-
工程发布记得将依赖包导入发布文件中
注意:FeeMarker写错了,页面会无法输出,甚至空白,时间格式要进行转换类的处理!