持续创作,加速成长!这是我参与「掘金日新计划 · 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;
}
自定义项目系统级异常
拦截器简介
拦截器(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)
2.定义配置类,继承WebMvcConfigurationSupport,实现addInterceptor方法(注意:扫描加载配置)
3.添加拦截器并设定拦截的访问路径,路径可以通过可变参数设置多个
4:使用标准接口webMvcConfigurer简化开发(注意:侵入式较强)
执行流程
拦截器参数
多拦截器执行顺序
当配置多个拦截器时,形成拦截器链
拦截器链的运行顺序参照拦截器添加顺序为准
当拦截器中出现对原始处理器的拦截,后面的拦截器均终止运行
当拦截器运行中断,仅运行配置在前面的拦截器的afterCompletion操作
若pre返回false,那么只运行pre1
若pre返回true,pre2返回false,只运行pre1,pre2,after1
若pre返回true,pre2返回true,只运行pre1,pre2,pre3,after1,after2