Ajax的请求在struts2中怎么实现跳转

我前台用的ext,所有请求都是Ajax的请求,然后我后台用的struts,配置了一个全局的权限拦截器。如果未登录就自动跳转到登陆界面。也配置了全局的跳转。

/login.jsp

但是因为是Ajax的请求,所以界面并不跳转。但是都可以在后台输出跳转
2010-05-13 17:05:49,281 DEBUG (org.apache.struts2.dispatcher.ServletRedirectResult:57) - Redirecting to finalLocation /graduation/login.jsp
用firedebug也有跳转到login.jsp的一个get方法。
后来想在拦截器里面直接用后台的代码跳转。
HttpServletRequest req = (HttpServletRequest) ctx.get(StrutsStatics.HTTP_REQUEST);
HttpServletResponse resp = (HttpServletResponse) ctx.get(StrutsStatics.HTTP_RESPONSE);
resp.sendRedirect(req.getContextPath()+"/login.jsp");

或者是 req.getRequestDispatcher("/login.jsp").forward(req, resp);
但是都会在后台报错:严重: Servlet.service() for servlet default threw exception
java.lang.IllegalStateException
at org.apache.catalina.connector.ResponseFacade.sendError(ResponseFacade.java:407)
at org.apache.struts2.dispatcher.Dispatcher.sendError(Dispatcher.java:770)
at org.apache.struts2.dispatcher.Dispatcher.serviceAction(Dispatcher.java:505)
at org.apache.struts2.dispatcher.ng.ExecuteOperations.executeAction(ExecuteOperations.java:77)
at org.apache.struts2.dispatcher.ng.filter.StrutsPrepareAndExecuteFilter.doFilter(StrutsPrepareAndExecuteFilter.java:91)
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:235)
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206)
at org.springframework.orm.hibernate3.support.OpenSessionInViewFilter.doFilterInternal(OpenSessionInViewFilter.java:198)
at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:76)
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:235)
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206)
at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:233)
at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:175)
at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:128)
at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:102)
at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:109)
at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:263)
at org.apache.coyote.http11.Http11Processor.process(Http11Processor.java:844)
at org.apache.coyote.http11.Http11Protocol$Http11ConnectionHandler.process(Http11Protocol.java:584)
at org.apache.tomcat.util.net.JIoEndpoint$Worker.run(JIoEndpoint.java:447)
at java.lang.Thread.run(Thread.java:619)
请教高手啦、、、、、

8个回答

由于你的请求都是采用Ajax的, 所以每次发起ajax请求, 虽然拦截器判断出未登录跳转到登录页面, 那么, [b]这次ajax请求的结果就是这个页面(具体的说, 这次请求返回的就是登录页面的源代码),[/b] 所以浏览器不会发生跳转. 通过在请求完成事件处理函数中判断返回的文本是不是登录页面的源码(比如检查返回值中是否包含

用户登录, 这个和登录页面有关了), 如果包含, 则top.location.href='登录页面的url'

既然你是用ajax请求 那么无论他如何跳转都没有用,他会将数据一大堆返回,还不方便ajax请求,你最好是在ajax的onsucess中手动跳转

不方便ajax处理

[code="java"]后来想在拦截器里面直接用后台的代码跳转。[/code]

在Interceptor中不能直接resp.sendRedirect(req.getContextPath()+"/login.jsp");

因为下一个Interceptor无法被调用。所以会报错

你可以这样:

[code="xml"]
/login.jsp
[/code]

讲讲解决思路:

1,使用filter过滤器,直接sendRedirect是完全可以的。(就如你下面的代码是完全正确的)

[code="java"]HttpServletRequest req = (HttpServletRequest) ctx.get(StrutsStatics.HTTP_REQUEST);
HttpServletResponse resp = (HttpServletResponse) ctx.get(StrutsStatics.HTTP_RESPONSE);
resp.sendRedirect(req.getContextPath()+"/login.jsp");
[/code]
为什么不能使用拦截器和上面同样的代码,这跟拦截器的实现机制有关系的,我们知道在struts中一个重要的机制是AOP编程,拦截器就是用AOP思想来实现的。所以同样的代码在filter中可以使用,而在拦截器中不可使用。

2,使用拦截器实现,但是逻辑稍微有点复杂。

大体思路是这样的:在拦截器中设置一个标识(表示是否登录),在login action中获取该标志,根据该标志的值进行跳转。(上面的代码依然可以用)
可以参考这个实现:http://www.blogjava.net/max/archive/2006/12/06/85925.html

[b][quote]我是这样子做的啊、[/quote]

你设置的是 redirect , 改为默认的 dispatcher就好了[/b]

AJAX请求是不可能在服务端完成跳转的,它只能将文本信息传回到客户端。你可以这么做,如果验证失败的话让拦截器将失败信息以一定的json格式写入输出流中,然后在js里为
Ext.ajax添加requestcomplete事件监听,对返的XMLHttpRequest 进行解析,如果responseText属性是验证失败的json串则在客户端通过window.location进行跳转;因为Ext.ajax是个单例对象,所以一个页面只需配置一次即可,多个页面的话你就得每个页面都复制了

我弄过
请看:http://fireinjava.iteye.com/blog/483931(同步异步皆可)

你也可以在interceptor里面getRootWin().location="http://....";

Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
立即提问