SSM整合(下)

116 阅读3分钟

持续创作,加速成长!这是我参与「掘金日新计划 · 6 月更文挑战」的第10天,点击查看活动详情

案例:SSM整合标准开发

列表,新增,跳转到修改,修改,删除

在加入前端页面时无法实现,是因为此时的前端页面也交由springMVC管理,从而无法找到前端页面

@Configuration
public class SpringMvcSupport extends WebMvcConfigurationSupport {
    @Override
    protected void addResourceHandlers(ResourceHandlerRegistry registry) {
        registry.addResourceHandler("/pages/**").addResourceLocations("/pages/");
        registry.addResourceHandler("/css/**").addResourceLocations("/css/");
        registry.addResourceHandler("/js/**").addResourceLocations("/js/");
        registry.addResourceHandler("/plugins/**").addResourceLocations("/plugins/");
    }
}

且在SpringMVC中加入如下注解

@ComponentScan({"com.itheima.controller","com.itheima.config"})

然后在html页面一顿操作(前端还不是很熟,等再学点前端内容再回来进行补充),vue是其中最关键的,因此vue需要多看

由于BookServiceImpl中的方法只返回true,即不管咋样都是方法成功。这时需要修改BookDao中的方法,将返回值类型从boolean修改为int。再在BookServiceImpl中判断返回的影响行数是否大于0,大于0就成功,否则就失败

public boolean save(Book book) {
    return bookDao.save(book) > 0;
}

public boolean update(Book book) {
    return bookDao.update(book) > 0;
}

public boolean delete(Integer id) {
    return bookDao.delete(id) > 0;
}

自定义项目系统级异常

image.png

拦截器简介

拦截器(Interceptor )是一种动态拦截方法调用的机制,在springNVC中动态拦截控制器方法的执行

作用:

1.在指定的方法调用前后执行预先设定的代码

2.阻止原始方法的执行

拦截器与过滤器区别

归属不同:Filter(过滤器)属于servlet技术,Interceptor(拦截器)属于SpringMVC技术

拦截内容不同:Filter(过滤器)对所有访问进行增强,Interceptor(拦截器)仅针对springMVc的访问进行增强

拦截器入门案例

1.制作拦截器功能类

PS:在preHandle()方法中返回false的话就会终止方法执行,也就是说只会执行preHandle()的执行语句,其他啥都不会输出

//定义拦截器类,实现HandlerInterceptor接口 //注意当前类必须受Spring容器控制

@Component
//定义拦截器类,实现HandlerInterceptor接口
//注意当前类必须受Spring容器控制
public class ProjectInterceptor implements HandlerInterceptor {
    @Override
    //原始方法调用前执行的内容
    //返回值类型可以拦截控制的执行,true放行,false终止
    public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
        String contentType = request.getHeader("Content-Type");
        HandlerMethod hm = (HandlerMethod)handler;
        System.out.println("preHandle..."+contentType);
        return true;
    }

    @Override
    //原始方法调用后执行的内容
    public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView) throws Exception {
        System.out.println("postHandle...");
    }

    @Override
    //原始方法调用完成后执行的内容
    public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex) throws Exception {
        System.out.println("afterCompletion...");
    }

2.配置拦截器的执行位置

@Configuration
@ComponentScan({"com.itheima.controller"})
@EnableWebMvc
//实现WebMvcConfigurer接口可以简化开发,但具有一定的侵入性
public class SpringMvcConfig implements WebMvcConfigurer {
    @Autowired
    private ProjectInterceptor projectInterceptor;
    @Autowired
    
    @Override
    public void addInterceptors(InterceptorRegistry registry) {
        //配置多拦截器
        registry.addInterceptor(projectInterceptor).addPathPatterns("/books","/books/*");
        
    }

跟上面步骤一样的

1:声明拦截器的bean,并实现HandlerInterceptor接口(注意:扫描加载bean)

image.png 2.定义配置类,继承WebMvcConfigurationSupport,实现addInterceptor方法(注意:扫描加载配置)

image.png 3.添加拦截器并设定拦截的访问路径,路径可以通过可变参数设置多个

image.png 4:使用标准接口webMvcConfigurer简化开发(注意:侵入式较强)

image.png

执行流程

image.png

拦截器参数

image.png

image.png

image.png

多拦截器执行顺序

当配置多个拦截器时,形成拦截器链

拦截器链的运行顺序参照拦截器添加顺序为准

当拦截器中出现对原始处理器的拦截,后面的拦截器均终止运行

当拦截器运行中断,仅运行配置在前面的拦截器的afterCompletion操作

image.png 若pre返回false,那么只运行pre1

若pre返回true,pre2返回false,只运行pre1,pre2,after1

若pre返回true,pre2返回true,只运行pre1,pre2,pre3,after1,after2