Spring 拦截器不工作 JAVA



我的项目中有这两个类。当我在配置中使用它们时,我无法提交项目的登录表单。填写凭据并单击登录后,我尝试调试应用程序,并意识到表单不会命中发出 post 请求的 methot。我不知道为什么,但是当从配置中删除拦截器时,我的登录没有问题。请帮忙。

会话拦截器.class

 public class SessionInterceptor extends HandlerInterceptorAdapter {
        @Autowired
        private SessionManager sm;
        @Autowired
        private MessageSourceAccessor msa;
        @SuppressWarnings("deprecation")
        public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler)
                throws Exception {
            String return_url = request.getRequestURL().toString() + "?" + request.getQueryString();
            return_url = return_url.replace(msa.getMessage("config.baseurl"), "");
            if (!request.getRequestURI().contains("login")) {
                if (sm.get(request) == null) {
                    response.sendRedirect(
                            msa.getMessage("config.baseurl") + "/login?return=" + URLEncoder.encode(return_url));
                    return false;
                }
            }
            return true;
        }
    }

会话管理器.class

@Component
public class SessionManager {
    public static final String ProfileUser = "profileuser";
    public UserModel get(HttpServletRequest request) {
        HttpSession session = null;
        session = request.getSession(false);
        if (session == null)
            return null;
        return (UserModel) session.getAttribute(ProfileUser);
    }
    public void set(HttpServletRequest request, UserModel auth) {
        HttpSession session = null;
        session = request.getSession(false);
        if (session == null)
            return;
        session.setAttribute(ProfileUser, auth);
    }
    public void remember(HttpServletRequest request) {
        HttpSession session = null;
        session = request.getSession(false);
        if (session != null)
            session.invalidate();
        session.setMaxInactiveInterval(60 * 60 * 60);
    }
    public void init(HttpServletRequest request, UserModel auth, Boolean remember) {
        HttpSession session = null;
        session = request.getSession(false);
        if (session != null)
            session.invalidate();
        session = request.getSession(true);
        if (remember)
            session.setMaxInactiveInterval(60 * 60 * 60 * 60);
        else
            session.setMaxInactiveInterval(1800);
        session.setAttribute(ProfileUser, auth);
    }
    public void destroy(HttpServletRequest request) {
        HttpSession session = null;
        session = request.getSession(false);
        if (session == null)
            return;
        session.removeAttribute(ProfileUser);
        session.invalidate();
    }

你能提供你的整个配置吗?作为您的代码的疯狂猜测:

if (!request.getRequestURI().contains("login")) {
    if (sm.get(request) == null) {
        response.sendRedirect(
                msa.getMessage("config.baseurl") + "/login?return=" + URLEncoder.encode(return_url));
        return false;
    }
}

现在,如果您的sm.get(request) == null则重定向将发生,因此调用将不会转到控制器。

重定向意味着再次调用到客户端,从那里将发起对所述 URL 的新调用。

如果您的@Autowire在这种情况下不起作用sm将为 null。 并且sm.get(request) == null将抛出NullPointerException。再次调用不会转到控制器。

但可以肯定的是,请提供您的配置。或者在拦截器中调试代码。

相关内容

  • 没有找到相关文章

最新更新