拦截器登录判断

网站后台进行操作,都会首先判断是否是登录用户,如果有一些方法,不需要登录也能调用该如何处理呢?直接上代码。

  public String intercept(ActionInvocation invocation) throws Exception {
        //检查用户是否已经登陆
        SessionalUser user = SessionUtils.getSessionalUser();
        boolean isLogin = LoginAction.class == invocation.getAction().getClass();       //是否是登陆动作
        boolean isRenZheng = RenZhengAction.class == invocation.getAction().getClass();
        //未登录 且 不是登陆请求
        if(user == null && !isLogin && !isRenZheng) {
            //修改ValueStack中的返回参数
            MethodResult result = MethodResult.timeoutResult();
            ValueStack valueStack = invocation.getStack();
            valueStack.set("jsonResult", result);

            return BaseAction.JSON_RESULT;
        }

//        return invocation.invoke(); //继续其他拦截器调用
        long start = System.currentTimeMillis();
        String result;
        try {
            result = invocation.invoke();
        } catch (NoSuchMethodException e) {
            result = Action.NONE;
        }
        long end = System.currentTimeMillis();
        if (TheApp.getDebugMode()) {
            logger.debug("\n=======================================\n" +
                    ((HttpServletRequest) invocation.getInvocationContext().get(ServletActionContext.HTTP_REQUEST)).getRequestURI() +
                    ":" + (end - start) + "ms\n=======================================");
        }
        return result;
    }

LoginAction是登录类,RenZhengAction里面的是不需要登录就可调用的方法。拦截器中,如果当前无活动用户,或者请求的方法不是Login和RenZheng中的方法,就直接返回一个无效的消息。其他情况则继续处理。

之前返回的都是不加try catch处理的,直接返回invocation.invoke()。后来看别人代码加了,我也加上了,好处如下。

客户端调用一个不存在的方法,如果不进行异常处理,则客户端会因为超时报错,加上异常之后,会因为消息解析错误报错,很明显,加上之后,响应时间更快。

在服务器端的output输出中,加上异常处理就不会报出找不到方法的异常,类似于下图这种



你可能感兴趣的:(java)