当前位置: 代码迷 >> Java Web开发 >> spring aop这个跳转异常是咋回事
  详细解决方案

spring aop这个跳转异常是咋回事

热度:9828   发布时间:2013-02-25 21:06:42.0
spring aop这个跳转错误是怎么回事、
代码如下。。
package com.jxtcmi.yd.aspect;

import java.util.Map;

import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

import org.apache.struts2.ServletActionContext;
import org.aspectj.lang.annotation.Aspect;
import org.aspectj.lang.annotation.Before;
import org.aspectj.lang.annotation.Pointcut;
import org.springframework.context.annotation.Scope;
import org.springframework.stereotype.Component;

import com.opensymphony.xwork2.ActionContext;
@Aspect
@Component("userLoginCheck1")
@Scope("singleton")
public class UserLoginCheck1{
    @Pointcut("execution(* com.jxtcmi.yd.ydadminMdao1..*.*(..))")
public void loginUser(){};

@Before("loginUser()")
public void beforeAllOperation()throws Exception{
HttpServletRequest request=ServletActionContext.getRequest();
    HttpServletResponse response=ServletActionContext.getResponse();
Map<String,Object> session=ActionContext.getContext().getSession();
String userId=(String) session.get("userId");
String managerId=(String) session.get("managerId");

if(userId==null&&managerId==null){
System.out.println("请你先登录。。");
response.sendRedirect(request.getContextPath()+"/index.jsp");
return ;
}
return;
}
}

运行之后报错如下。。

信息: Server startup in 60786 ms
请你先登录。。
2012-12-19 13:17:51 org.apache.catalina.core.StandardWrapperValve invoke
严重: 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:725)
at org.apache.struts2.dispatcher.Dispatcher.serviceAction(Dispatcher.java:485)
at org.apache.struts2.dispatcher.ng.ExecuteOperations.executeAction(ExecuteOperations.java:77)
at org.apache.struts2.dispatcher.ng.filter.StrutsPrepareAndExecuteFilter.doFilter(StrutsPrepareAndExecuteFilter.java:76)
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:235)
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:206)
at com.jxtcmi.yd.ydutil.EncodingFilter.doFilter(EncodingFilter.java:22)
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:230)
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:104)
at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:109)
at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:261)
at org.apache.coyote.http11.Http11Processor.process(Http11Processor.java:844)
at org.apache.coyote.http11.Http11Protocol$Http11ConnectionHandler.process(Http11Protocol.java:581)
at org.apache.tomcat.util.net.JIoEndpoint$Worker.run(JIoEndpoint.java:447)
at java.lang.Thread.run(Thread.java:619)
这种错误,是你在不恰当的时机进行了请求导致的。你这个aop是拦截了com.jxtcmi.yd.ydadminMdao1下的所有方法之前做这些登陆判断。判断完了确进行了跳转这个显然是不恰当的调用请求。dao不是action不是service怎么能进行重定向呢。这些登陆判断应该用struts2的拦截器去做。这样才能恰当调用请求
  相关解决方案