SpringMVC(三)——【拦截器、异常处理机制】

发布时间:2022-07-02 发布网站:脚本宝典
脚本宝典收集整理的这篇文章主要介绍了SpringMVC(三)——【拦截器、异常处理机制】脚本宝典觉得挺不错的,现在分享给大家,也给大家做个参考。

目录

拦截器(interceptor)的作用

拦截器快速入门 

案例F1a;用户登录权限控制

拦截器方法说明

SPRingMVC异常处理 

 异常处理的思路

 异常处理两种方式


拦截器(interceptor)的作用

Spring MVC的拦截器类似于Servlet开发中的过滤器Filter,用于对处理器进行预处理后处理。 将拦截器按一定的顺序联结成一条链,这条链称为拦截器链(Interceptor Chain)。在访问被拦截的方法或字段时,拦截器链中的拦截器就会按其之前定义的顺序被调用。拦截器也是AOP思想的具体实现。

拦截器和过滤器区别  

SpringMVC(三)——【拦截器、异常处理机制】

拦截器快速入门 

拦截器快速入门自定义拦截器很简单,只有如下三步:

①创建拦截器类实现Handlerlnterceptor接口 ②配置拦截器 ③测试拦截器的拦截效果

①创建拦截器类实现Handlerlnterceptor接口

public class MyInterceptor1 implements HandlerInterceptor {
    //在目标方法执行之前 执行
    public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws ServletException, IOException {
        System.out.println("preHandle.....");
        String param = request.getParameter("param");
        if("yes".equals(param)){
            return true;
        }else{
            request.getRequestDispatcher("/error.jsp").forward(request,response);
            return false;//返回true代表放行  返回false代表不放行
        }
    }

    //在目标方法执行之后 视图对象返回之前执行
    public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView) {
        modelAndView.addObject("name","ITheima");
        System.out.println("postHandle...");
    }

    //在流程都执行完毕后 执行
    public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex) {
        System.out.println("afterCompletion....");
    }
}

②配置拦截器

     <;mvc:interceptors>    
         <mvc:interceptor>
            <!--对哪些执行拦截操作-->
            <mvc:mapping path="/**"/>
            <bean class="com.longdi.interceptor.MyInterceptor1"/>
        </mvc:interceptor>
    </mvc:interceptors>

③测试拦截器的拦截效果

@Controller
public class TargetController {

    @RequestMapping("/target")
    public ModelAndView show(){
        System.out.println("目标资源执行......");
        ModelAndView modelAndView = new ModelAndView();
        modelAndView.addObject("name","itcast");
        modelAndView.setViewName("index");
        return modelAndView;
    }

}

案例:用户登录权限控制

需求:用户没有登录的情况下,不能对后台菜单进行访问操作,点击菜单跳转到登录页面,只有用户登录成功后才能进行后台功能的操作  

public class PrivilegeInterceptor implements HandlerInterceptor {

    public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws IOException {
        //逻辑:判断用户是否登录  本质:判断session中有没有user
        HttpSession session = request.getSession();
        User user = (User) session.getAttribute("user");
        if(user==null){
            //没有登录
            response.sendredirect(request.getContextPath()+"/login.jsp");
            return false;
        }

        //放行  访问目标资源
        return true;
    }
}

spring-mvc.XMl:

<mvc:interceptors>
    <mvc:interceptor>
        <!--配置对哪些资源执行拦截操作-->
        <mvc:mapping path="/**"/>
        <!--配置哪些资源排除拦截操作-->
        <mvc:exclude-mapping path="/user/LOGin"/>
        <bean class="com.longdi.interceptor.PrivilegeInterceptor"/>
    </mvc:interceptor>
</mvc:interceptors>

SpringMVC(三)——【拦截器、异常处理机制】

SpringMVC(三)——【拦截器、异常处理机制】

 UserServiceImpl

    public User login(String username, String password) {
        try {
            User user = userDAO.findByUsernameAndPassword(username,password);
            return user;
        }catch (EmptyResultDataAccessException e){
            return null;
        }
    }

UserService

    User login(String username, String password);

UserDaoImpl

    public User findByUsernameAndPassword(String username, String password) throws EmptyResultDataAccessException {
        User user = jdbcTemplate.queryForObject("select * From sys_user where username=? and password=?", new BeanProPErtyRowMapper<User>(User.class), username, password);
        return user;
    }

UserDao

    User findByUsernameAndPassword(String username, String password);

拦截器方法说明

SpringMVC(三)——【拦截器、异常处理机制】

SpringMVC异常处理 

@H_831_126@异常处理的思路

系统中异常包括两类∶预期异常运行时异常RuntimeException,前者通过捕获异常从而获取异常信息,后者主要通过规范代码开发、测试等手段减少运行时异常的发生。 系统的Dao、Service、Controller出现都通过throws Exception向上抛出,最后由SpringMVC前端控制器交由异常处理器进行异常处理,如下图:

SpringMVC(三)——【拦截器、异常处理机制】

 异常处理两种方式

1、使用Spring MVC提供的简单异常处理器SimpleMappingExceptionResolver

SpringMVC已经定义好了该类型转换器,在使用时可以根据项目情况进行相应异常与视图的映射配置

SpringMVC(三)——【拦截器、异常处理机制】

 2、实现Spring的异常处理接口HandlerExceptionResolver自定义自己的异常处理器

①创建异常处理器类实现HandlerExceptionResolver

public class MyExceptionResolver implements HandlerExceptionResolver {

    /*
        参数Exception:异常对象
        返回值ModelAndView:跳转到错误视图信息
     */
    public ModelAndView resolveException(HttpServletRequest httpServletRequest, HttpServletResponse httpServletResponse, Object o, Exception e) {
        ModelAndView modelAndView = new ModelAndView();

        if(e instanceof MyException){
            modelAndView.addObject("info","自定义异常");
        }else if(e instanceof ClassCastException){
            modelAndView.addObject("info","类转换异常");
        }

        modelAndView.setViewName("error");

        return modelAndView;
    }
}

②配置异常处理器

    <!--自定义异常处理器-->
    <bean  class="com.longdi.resolver.MyExceptionResolver"/>

③编写异常页面


<%@ page contentType="text/htML;charset=UTF-8" language="java" %>
<html>
<head>
    <title>Title</title>
</head>
<body>
    <h1>通用的错误提示页面</h1>
    <h1>${info}</h1>
</body>
</html>

④测试异常跳转

SpringMVC(三)——【拦截器、异常处理机制】

SpringMVC(三)——【拦截器、异常处理机制】

脚本宝典总结

以上是脚本宝典为你收集整理的SpringMVC(三)——【拦截器、异常处理机制】全部内容,希望文章能够帮你解决SpringMVC(三)——【拦截器、异常处理机制】所遇到的问题。

如果觉得脚本宝典网站内容还不错,欢迎将脚本宝典推荐好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。