spring MVC框架

spring MVC框架
如果你对spring MVC框架有一些疑问,那么以下文章或许可以帮助到你
为什么要学习spring MVC框架
因为它非常的好用,可以说提高了你的效率不止一星半点,可以免去写那些之前的重复代码,让你大部分精力都在业务上
虽然它简易,但效率却一点也不低,选择Spring MVC吧
先让我们来创建第一个mvc项目
创建一个maven项目
导入我们所需要的mvc依赖

org.springframework spring-webmvc 5.3.15 javax.servlet javax.servlet-api 4.0.1 provided 创建SpringMvc配置文件 以下为SpringMvc配置文件格式,请根据实际情况变动 /** * SpringMVC配置类 */ @Configuration //1.标识当前是配置类 指定这个类为配置类,替代application.xml @ComponentScan("com.zbbmeta")//2.配置扫描web层包 代替 @EnableWebMvc //如果使用接口的方式,拦截器需要添加这个注解。不建议使用这种方式,两种方式只能配置一种,否则会有冲突 public class SpringMvcConfig { } 创建Web容器初始化的配置类 public class ServletConfig extends AbstractAnnotationConfigDispatcherServletInitializer {
// 暂时不管,整合Spring才需要
@Override
protected Class<?>[] getRootConfigClasses() {
    return new Class[0];
}
//在tomcat启动时调用,用于创建springmvc框架的IOC容器对象
//加载springmvc配置类, Tomcat会拿这个配置类去创建IoC容器,产生springmvc容器(本质还是spring容器)
@Override
protected Class<?>[] getServletConfigClasses() {
    return new Class[] {SpringMvcConfig.class};
}
// 指定SpringMVC要处理哪些请求, /表示SpringMVC处理项目中的所有请求, 静态资源不要让SpringMVC处理,要放行
//设置DispatcherServlet绑定处理请求的路径"/",处理除了jsp的所有资源请求
@Override
protected String[] getServletMappings() {
    return new String[] {"/"};
}

}
创建控制器
package com.zbbmeta.controller;

import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

@RestController
@RequestMapping("/student")//RequestMapping可以在类或者方法上添加
public class StudentController {
/**
* 查找Student
*/
@RequestMapping("/find")
public String find(HttpServletRequest request, HttpServletResponse response) {
System.out.println("查找Student");
return "find success";
}
}
在mvc中,我们有拦截器可以使用
以下为配置拦截器的方式
定义一个类,实现HandlerInterceptor接口即可
package com.zbbmeta.Iinterceptor;

import org.springframework.web.servlet.HandlerInterceptor;
import org.springframework.web.servlet.ModelAndView;

import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

public class StudentInterceptor implements HandlerInterceptor {
//原始方法调用前执行的内容
//返回值类型可以拦截控制的执行,true放行,false终止
@Override
public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
System.out.println("=前置通知=");
return true;
}
//原始方法调用后执行的内容
@Override
public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView) throws Exception {
System.out.println("=后置通知=");
}
//原始方法调用完成后执行的内容
@Override
public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex) throws Exception {
System.out.println("=最终通知=");
}
}
配置加载拦截器
配置加载拦截器的方式有两种我们分别介绍:

加载拦截器方法1:
注:@Configuration注解已经包含@Component的功能

在上面添加静态资源的配置类中重写addInterceptors方法
添加拦截器和多个拦截路径:/book和/book/**
要注入拦截器对象
package com.zbbmeta.config;

import com.zbbmeta.Iinterceptor.StudentInterceptor;
import org.springframework.context.annotation.Configuration;
import org.springframework.web.servlet.config.annotation.InterceptorRegistry;
import org.springframework.web.servlet.config.annotation.WebMvcConfigurationSupport;

@Configuration
public class SpringMvcSupport extends WebMvcConfigurationSupport {

@Override
protected void addInterceptors(InterceptorRegistry registry) {
    //注解拦截器和拦截地址   表示添加 StudentInterceptor  取拦截路径是 /student/* 所有请求
    registry.addInterceptor(new StudentInterceptor()).addPathPatterns("/student/*");
}

}
加载拦截器方法2:
使用标准接口WebMvcConfigurer简化开发(注意:侵入式较强)

在SpringMvcConfig主配置类上实现WebMvcConfigurer接口,接口中全是默认方法
注入拦截器对象,重写addInterceptors方法
注:与方式一两者只能选一种,不然会有冲突,如果方式一起作用会导致第二种方式的拦截器不起使用。

即:如果项目中出现了一次 extends WebMvcConfigurationSupport ,其他的 extends WebMvcConfigurationSupport 和 implements WebMvcConfigurer 会失效 。

/**

  • SpringMVC配置类
    /
    @Configuration //1.标识当前是配置类 指定这个类为配置类,替代application.xml
    @ComponentScan("com.zbbmeta")//2.配置扫描web层包 代替<context:component-scan base-package="com.zbbmeta" />
    @EnableWebMvc //如果使用接口的方式,拦截器需要添加这个注解。不建议使用这种方式,两种方式只能配置一种,否则会有冲突
    public class SpringMvcConfig implements WebMvcConfigurer {
    @Override
    public void addInterceptors(InterceptorRegistry registry) {
    //注解拦截器和拦截地址 表示添加 StudentInterceptor 取拦截路径是 /student/
    所有请求
    registry.addInterceptor(new StudentInterceptor()).addPathPatterns("/student/*");
    }
    }

拦截器参数
前置处理
//原始方法调用前执行的内容
//返回值类型可以拦截控制的执行,true放行,false终止
@Override
public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
System.out.println("=前置通知=");
return true;
}
参数
request:请求对象
response:响应对象
handler:被调用的处理器对象,本质上是一个方法对象,对反射技术中的Method对象进行了再包装
返回值 返回值为false,被拦截的处理器将不执行。
3.2 后置处理
//原始方法调用后执行的内容
@Override
public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView) throws Exception {
System.out.println("=后置通知=");
}
参数 modelAndView:如果处理器执行完成具有返回结果,可以读取到对应数据与页面信息,并进行跳转
注意:如果处理器方法出现异常了,该方法不会执行
后置处理
//原始方法调用后执行的内容
@Override
public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView) throws Exception {
System.out.println("=后置通知=");
}
参数 modelAndView:如果处理器执行完成具有返回结果,可以读取到对应数据与页面信息,并进行跳转
注意:如果处理器方法出现异常了,该方法不会执行
完成后处理
//原始方法调用完成后执行的内容
@Override
public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex) throws Exception {
System.out.println("=最终通知=");
}
参数 ex:如果处理器执行过程中出现异常对象,可以针对异常情况进行单独处理
注意:无论处理器方法内部是否出现异常,该方法都会执行。

posted @ 2024-01-25 23:50  小手一拍伤害你猜  阅读(12)  评论(0)    收藏  举报