我们的应用程序要求用户登录才能查看任何内容。 LoginInterceptor 拦截对所有页面的访问,如果用户没有有效会话,则会显示登录表单。我希望拦截器在显示登录表单之前记住原始请求URI,并在登录表单验证成功时重定向到它。我尝试按照 Struts 2 Redirect更正身份验证拦截器后的操作。
Our application requires users to be logged in to view any content. Access to all pages is intercepted by LoginInterceptor which brings up the login form if there's no valid session for the user. I'd like the interceptor to remember the original request URI before displaying the login form and redirect to it if the login form validation is successful. I tried to follow Struts 2 Redirect to correct action after authentication interceptor.
@Service @Results({ @Result(name = "redirect", type = "redirect", location = "${savedUrl}") }) public class LoginInterceptor extends AbstractInterceptor { //... private String savedUrl; //... @Override public final String intercept(final ActionInvocation invocation) throws Exception { // ... savedUrl = (String) session.getAttribute("savedUrl"); // ... if (processLogin(request, session)) { // validate login form if (!StringUtils.isEmpty(savedUrl)) { return "redirect"; } return LOGIN_SUCCESS_RESULT; } // if there's no loginData in sesssion, remeber the URI and display a login form String queryString = request.getQueryString(); session.setAttribute("savedUrl", request.getRequestURI() + (queryString==null ? "" : ("?" + queryString))); return "login"; } // ... public String getSavedUrl(){ return savedUrl; } }但是我得到一个空白页面返回重定向。永远不会调用 getSavedUrl()。
However I get a blank page as a result of return "redirect". getSavedUrl() is never called.
解决方案:完全刮开@Results注释而不是返回重定向; 调用 response.sendRedirect(savedUrl); return null;
Solution: scratch the @Results annotation completely and instead of return "redirect"; call response.sendRedirect(savedUrl); return null;
推荐答案如果没有登录,则重定向到 LOGIN 结果。然后你应该重写你的拦截器类似
If not logged in then redirect to LOGIN result. Then you should rewrite your interceptor something like
public final String intercept(final ActionInvocation invocation) throws Exception { // before save original url Map session = invocation.getInvocationContext().getSession(); Object action = invocation.getAction(); if (!(action instanceof LoginAction)){ String queryString = request.getQueryString(); session.put("savedUrl", request.getRequestURI()+(queryString==null?"":("?"+queryString))); } else { return invocation.invoke(); } if (!processLogin(request, session)) { //return false if not authenticated session.put("isLogin", true); return Action.LOGIN; } else { savedUrl = (String) session.get("savedUrl"); boolean isLogin = (boolean)session.get("isLogin"); if (!StringUtils.isEmpty(savedUrl) && isLogin) { session.put("isLogin", false); return "redirect"; } return invocation.invoke(); } }更多推荐
Struts2从登录拦截器重定向
发布评论