struts2提供了声明式异常处理,可以针对不同的异常做不同的处理。我想拦截Action中的所有异常,然后通过Log4j进行日志记录,再呈现到页面。
首先在struts配置文件中配上一个全局的java.lang.Exception。这样所有异常都会被这个exception-mapping所拦截,并返回一个name为ALL_EXCEPTION的result
再来配置一个<global-results>来处理异常,通过chain跳转到exectionHandle这个action中
exectionHandle配置,这里的action用spring来管理的(exectionHandleAction)。处理异常后返回到指定界面(界面用的veloctiy模板)。
最后看一下action中的处理,直接用logo4j输出。
首先在struts配置文件中配上一个全局的java.lang.Exception。这样所有异常都会被这个exception-mapping所拦截,并返回一个name为ALL_EXCEPTION的result
<global-exception-mappings>
<exception-mapping result="ALL_EXCEPTION" exception="java.lang.Exception"/>
</global-exception-mappings>
<exception-mapping result="ALL_EXCEPTION" exception="java.lang.Exception"/>
</global-exception-mappings>
再来配置一个<global-results>来处理异常,通过chain跳转到exectionHandle这个action中
<global-results>
<result name="ALL_EXCEPTION" type="chain">exectionHandle</result>
</global-results>
<result name="ALL_EXCEPTION" type="chain">exectionHandle</result>
</global-results>
exectionHandle配置,这里的action用spring来管理的(exectionHandleAction)。处理异常后返回到指定界面(界面用的veloctiy模板)。
<action name="exectionHandle" class="exectionHandleAction">
<result type="velocity">/WEB-INF/public_ucenter_shopmanage/ServerExceptionPage.html</result>
</action>
<result type="velocity">/WEB-INF/public_ucenter_shopmanage/ServerExceptionPage.html</result>
</action>
最后看一下action中的处理,直接用logo4j输出。
public class ExceptionHandleAction extends ActionSupport{
private static final long serialVersionUID = 6019598646317953160L;
private static Logger logger = Logger.getLogger(ExceptionHandleAction.class);
@Override
public String execute() throws Exception {
String logoInfo = ActionContext.getContext().getValueStack().findString("exceptionStack");
logger.info(logoInfo);
logger.debug(logoInfo);
return SUCCESS;
}
}
private static final long serialVersionUID = 6019598646317953160L;
private static Logger logger = Logger.getLogger(ExceptionHandleAction.class);
@Override
public String execute() throws Exception {
String logoInfo = ActionContext.getContext().getValueStack().findString("exceptionStack");
logger.info(logoInfo);
logger.debug(logoInfo);
return SUCCESS;
}
}