- Spring-Mvc 笔记
- 跨域
- SpringMvc获取参数
- SpringMvc响应
- 上传文件
- 拦截器
interceptor
AOP
- SpringMvc.xml中配置
- pom.xml坐标
- web.xml配置
Spring-Mvc 笔记
跨域
@Controller 类前面 或者业务方法前面 加上
@CrossOrigin
就能实现后端 CORS跨域 但是一般情况 跨域都是由前端解决的
SpringMvc获取参数
获取基本参数类型
@Controller 类中的 业务方法 参数必须名必须和URL中的参数名一致
/* stringMvc 可以帮我们做基础类型的转换 比如String转Int Int转 String */
/* url = http://localhost:8080/er?name=1&id=12 */
void save(String name,int id){
}
获取POJO类型
@Controller 类中的 业务方法 参数是一个对象 对象的属性和POJO的属性名一致 或者和参数名一致
/* get请求 参数 和对象属性一致 */
var url = "localhost:8080/test/save?name=张三&age=18&sex=男"
/* 发送过去的数据 为json数据 双方属性名一致 */
{
name:"张三",
age:18,
sex:"男"
}
/* 接收数据 */
class Obj{
String name;
String sex;
int age;
/* getter/setter... */
}
@Controller
@RequestMapping(value = "/test")
public class Controller{
@RequestMapping(value = "/save")
void save(Obj name){
}
}
获取数组类型
@Controller 类中的业务方法数组名称与请求参数重复名称一致
var url = "localhost:8080/test/save?name=张三&name=李四"
@Controller
@RequestMapping(value = "/test")
public class Controller{
@RequestMapping(value = "/save")
void save(String[] name){
}
}
获取集合类型
首先得让获取集合参数需要将参数封装到POJO中
@Controller 类中的业务方法数组名称与请求参数重复名称一致
/* 发送过去的数据 为json数据 双方属性名一致 */
[{
name:"张三",
age:18,
sex:"男"
},{
name:"李四",
age:19,
sex:"男同"
}]
/* 接收数据 */
class Obj{
String name;
String sex;
int age;
/* getter/setter... */
}
@Controller
@RequestMapping(value = "/test")
public class Controller{
@RequestMapping(value = "/save")
void save(List<Obj> obj){
}
}
@RequestParam参数绑定
@Controller 类中的业务方法参数 和请求中参数名字不一致时
var url = "localhost:8080/test/save?name=张三"
@ResquestParam(参数)
value 请求中参数名
required 参数是否必须
defalutValue 当请求中没有指定参数时的默认值
@Controller
@RequestMapping(value = "/test")
public class Controller{
@RequestMapping(value = "/save")
void save(@requestParam("name") String userName){
}
}
Restful风格参数
url /user/1?name=张三 中 1 就是参数 使用springMvc占位符绑定
var url = "localhost:8080/test/save/1?name=张三"
@PathVarible(参数)
value 请求路径占位符名
required 参数是否必须
@Controller
@RequestMapping(value = "/test")
public class Controller{
@RequestMapping(value = "/save/{name}")
void save(@PathVarible(value = "name" ,required = false) String name){
}
}
获得请求头
@RequestHeader 用来获取 请求头
添加头 name
@RequestHeader(参数)
value 请求头名称
required 是否必须携带这个请求头
@Controller
@RequestMapping(value = "/test")
public class Controller{
@RequestMapping(value = "/save/{name}")
void save(@RequestHeader(value = "name" ,required = false) String header){
}
}
获得Cookie
@CookieValue 用来获取 浏览器的Cookie
@CookieValue(参数)
value Cookie名称
required 是否必须携带这个Cookie
@Controller
@RequestMapping(value = "/test")
public class Controller{
@RequestMapping(value = "/save/{name}")
void save(@RequestHeader(value = "name" ,required = false) String header){
}
}
SpringMvc响应
回显数据
/* 控制层 用在类上面 把类交给spring容器 */
@Controller
/* value 请求路径 */
@RequestMapping(value = "/test" )
public class Controller{
/* 方法上 加上 @ResponseBody 不在返回视图模型 可以用于返回json数据*/
@RequestMapping(value = "/save")
@ResponseBody
String save(){
return "hello world";
}
}
如果需要返回Json数据 需要在xml中配置Json解析器 推荐使用 SpringMvc注解驱动
上传文件
文件上传的3要素
- 表单的类型
type = "flie"
- 表单的提交必须使用
POST
方式 - 表单的
enctype
属性是多部分表单形式,enctype="multipart/from-data"
依赖导入
点击查看依赖导入
依赖注入文件上传解析器
点击查看依赖注入 文件上传解析器
html
代码
<!-- 前端表单的input 标签的input 标签 name属性必须和后端 业务方法的参数名一致 -->
<form action="http://localhost:8080/test/save3" method="POST" enctype="multipart/form-data">
名称:<input type="text" name="name"/><br/>
文件:<input type="file" name="upFile"/><br/>
<button type="submit" value="提交"></button>
</form>
java
代码
@Controller
@RequestMapping(value = "/test" )
public class Controller {
@RequestMapping("/save3")
@ResponseBody
public void save3(String name, MultipartFile upFile){
upFile.transferTo(new File("路径"+"文件名"+".后缀"));
}
}
多文件上传
html
<!-- 前端表单的input 标签的input 标签 name属性必须和后端 业务方法的参数名一致 -->
<form action="http://localhost:8080/test/save3" method="POST" enctype="multipart/form-data">
名称:<input type="text" name="name"><br/>
文件:<input type="file" name="upFile"><br/>
文件:<input type="file" name="upFile"><br/>
文件:<input type="file" name="upFile"><br/>
<button type="submit" value="提交"></button>
</form>
java
@Controller
@RequestMapping(value = "/test" )
public class Controller {
@RequestMapping("/save3")
@ResponseBody
public void save3(String name, MultipartFile[] upFile){
for (MultipartFile file : upFile) {
file.transferTo(new File("路径"+"文件名"+".后缀"));
}
}
}
拦截器 interceptor
拦截器类似于
过滤器
用于对数据的预处理
和后处理
拦截器可以用一定的顺序联成一条链 称为拦截器链
配置拦截器
实现HandlerInterceptor
接口
public class MyInterceptor implements HandlerInterceptor {
/* 访问资源之前 */
@Override
public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
return true;
}
/* 资源返回之前 */
@Override
public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView) throws Exception {
}
/* 资源返回之后 */
@Override
public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex) throws Exception {
}
}
AOP
依赖
Xml
方式
目标类 和 目标接口
class Target implements TargetInterface{
@Override
public void save() {
System.out.println("save run...");
}
}
interface TargetInterface{
void save();
}
切面类
class MaAspect{
public void before(){
System.out.println("前置");
}
}
配置
<!-- 目标对象 -->
<bean id="target" class="全限定名"></bean>
<!-- 切面对象 -->
<bean id="aspect" class="全限定名"></bean>
<!-- 配置 -->
<aop:config>
<!-- 声明切面 -->
<aop:aspect ref="aspect">
<!-- 切面对象 切点 -->
<aop:before method="before" pointcut="execution(返回类型 包名.类名.方法名)">
</aop:before>
</aop:aspect>
</aop:config>
切点表达式
execution([修饰符]返回值类型包名.类名.方法名(参数))
访问修饰符 可以省略
返回类型
包名
类名
方法名
可以使用*
代替
如果包名后面是… 表示当前包以及子类
参数列表可以使用… 代替 表示所有参数类型
通知类型
<aop:通知类型 method=“通知方法” pointcut=“切点表达式” ></aop:before>
前置 目标方法之前执行
<aop:before>
后置 目标方法之后执行
<aop:after-returning>
环绕 目标方法前后都执行
<aop:around>
异常 抛出异常执行
<aop:throwing>
最终 不管怎样最后都执行
<aop:throwing>
切点表达式的 抽取
<aop:poincut id=“my” expression=“切点表达式”>
使用
<aop:通知类型 method=“通知方法” pointcut=“id” ></aop:before>
注解
方式
目标类 和 目标接口
目标交给Spring容器 @Component
@Component
class Target implements TargetInterface{
@Override
public void save() {
System.out.println("save run...");
}
}
interface TargetInterface{
void save();
}
切面类
交给Spring 容器
加上@Aspect注解
@Component
@Aspect
class MaAspect{
}
通知
方法前加上
@通知类型
注解
@通知类型("切点表达式")
前置
@Before("切点")
public void func(){
System.out.println("前置");
}
后置
@AfterReturning("切点")
public void func(){
System.out.println("后置");
}
环绕
@Around("切点")
public void func(){
System.out.println("环绕");
}
异常
@AfterThrowing(切点"")
public void func(){
System.out.println("异常");
}
最终
@After(切点"")
public void func(){
System.out.println("最后");
}
配置组件扫描
扫描目标类 和 切面类
配置
AOP自动代理
配置到 Spring.xml 文件当中
<apo:aspectj-autoproxy/>
SpringMvc.xml中配置
命名空间
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns:context="http://www.springframework.org/schema/context"
xmlns:mvc="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">
</beans>
拦截器
<!--拦截器-->
<mvc:interceptors>
<mvc:interceptor>
<!-- /** 表示所有的请求路径都会被拦截-->
<mvc:mapping path="/**"/>
<bean class="包名.类名"/>
<!-- 可以使用 <mvc:exclude-mapping path=""/> 设置排除路径 -->
</mvc:interceptor>
</mvc:interceptors>
组件扫描
<!-- 组件扫描 扫描controller-->
<context:component-scan base-package="包名"></context:component-scan>
注解驱动
<!-- 注解驱动 用于返回数据为 Json-->
<mvc:annotation-driven></mvc:annotation-driven>
静态资源权限开放
<!-- 静态资源权限开放-->
<!-- <mvc:resources mapping="/路径/文件"mapping="/js/**" location="/js/"> -->
<mvc:default-servlet-handler/>
文件上传依赖注入文件上传解析器
<!-- 文件上传解析器 -->
<bean id="multipartResolver" class="org.springframework.web.multipart.commons.CommonsMultipartResolver">
<!-- 上传文件的总的最大值-->
<property name="maxUploadSize" value="50000"/>
<!--上传文件单个最大值-->
<property name="maxUploadSizePerFile" value="50000"/>
<!--上传文件的编码类型-->
<property name="defaultEncoding" value="UtF-8"/>
</bean>
pom.xml坐标
数据库依赖
<!-- 数据库 -->
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>5.1.49</version>
<scope>runtime</scope>
</dependency>
<dependency>
<groupId>com.alibaba</groupId>
<artifactId>druid</artifactId>
<version>1.1.24</version>
</dependency>
SpringMvc
<!-- spring -->
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-webmvc</artifactId>
<version>5.0.8.RELEASE</version>
</dependency>
<dependency>
<groupId>org.aspectj</groupId>
<artifactId>aspectjweaver</artifactId>
<version>1.8.13</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-jdbc</artifactId>
<version>5.0.8.RELEASE</version>
</dependency>
测试
<!-- 测试相关 -->
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-test</artifactId>
<version>5.0.8.RELEASE</version>
<scope>test</scope>
</dependency>
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>4.13</version>
<scope>test</scope>
</dependency>
项目共用
<dependency>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
<version>1.18.12</version>
<scope>provided</scope>
</dependency>
servlet
本地CLASSPATH设置了可以不用
<!-- servlet -->
<dependency>
<groupId>javax.servlet</groupId>
<artifactId>javax.servlet-api</artifactId>
<version>4.0.1</version>
<scope>provided</scope>
</dependency>
页面标签
<!-- 页面标签-->
<dependency>
<groupId>org.apache.taglibs</groupId>
<artifactId>taglibs-standard-spec</artifactId>
<version>1.2.5</version>
</dependency>
<dependency>
<groupId>org.apache.taglibs</groupId>
<artifactId>taglibs-standard-impl</artifactId>
<version>1.2.5</version>
</dependency>
Json
数据解析 jackson
<dependency>
<groupId>com.fasterxml.jackson.core</groupId>
<artifactId>jackson-core</artifactId>
<version>2.9.8</version>
</dependency>
<dependency>
<groupId>com.fasterxml.jackson.core</groupId>
<artifactId>jackson-databind</artifactId>
<version>2.9.8</version>
</dependency>
文件上传fileupload
<dependency>
<groupId>commons-io</groupId>
<artifactId>commons-io</artifactId>
<version>2.6</version>
</dependency>
<dependency>
<groupId>commons-fileupload</groupId>
<artifactId>commons-fileupload</artifactId>
<version>1.3.2</version>
</dependency>
web.xml配置
<?xml version="1.0" encoding="UTF-8"?>
<web-app version="2.4"
xmlns="http://java.sun.com/xml/ns/j2ee"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://java.sun.com/xml/ns/j2ee http://java.sun.com/xml/ns/j2ee/web-app_2_4.xsd">
<!-- 监听器 -->
<!-- <listener>-->
<!-- <listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>-->
<!-- </listener>-->
<!-- 过滤器 -->
<filter>
<filter-name>springFilter</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>springFilter</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
<!-- 使用SpringMvc给我们提供的Servlet -->
<servlet>
<servlet-name>springMvc</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>
<init-param>
<param-name>encoding</param-name>
<param-value>UTF-8</param-value>
</init-param>
<load-on-startup>1</load-on-startup>
</servlet>
<servlet-mapping>
<servlet-name>springMvc</servlet-name>
<url-pattern>/</url-pattern>
</servlet-mapping>
</web-app>