您的位置:首页 > 编程语言 > Java开发

SSH框架中如何输出访问的Action路径和页面

2014-11-07 19:01 330 查看
在一般的SSH框架开发的系统中后期会有很多的类和jsp,如果需要维护就需要去配置文件中一个一个的去找相应的类映射和返回的jsp页面,非常麻烦。
其实利用struts2的Interceptor可以很轻易的拦截到访问路径和jsp,原理自行参看struts2的结构图。
下面是实现输入路径的方法:
public class SystemOutPrint implements Interceptor {

public void destroy() {
// TODO Auto-generated method stub
}

public void init() {
// TODO Auto-generated method stub
}

public String intercept(ActionInvocation invocation) throws Exception {
Date d1 = new Date();// 计时开始
SimpleDateFormat dateFormat = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
String a1 = dateFormat.format(d1);
System.out.println("【请求开始】" + a1);

System.out.print("Action:" + invocation.getAction().getClass().getName());
HttpServletRequest request = ServletActionContext.getRequest();
String currentURL = request.getRequestURI();
String[] split = currentURL.split("/");
System.out.println("." + split[split.length - 1]);

Map<String, Object> parameters = invocation.getInvocationContext().getParameters();

// 输出传参
for (String key : parameters.keySet()) {
String[] params = (String[]) parameters.get(key);
StringBuffer buffer = new StringBuffer();
for (String param : params) {
buffer.append("," + param);
}
String paramValue = buffer.toString();
paramValue = paramValue.substring(1);
System.out.println(key + "," + paramValue);
}

final String resultCode = invocation.invoke();// 拦截器分界

// 输出页面
Result realResult = invocation.getResult();
if (realResult instanceof ServletDispatcherResult) {
ServletDispatcherResult result = (ServletDispatcherResult) realResult;
System.out.println("jsp:" + result.getLastFinalLocation());
}

Date d2 = new Date();// 计时结束
System.out.println("【本次操作耗时 " + (d2.getTime() - d1.getTime()) + " 毫秒】");// 输出耗时
return resultCode;
}

}


前后各加一个时间统计下程序执行用时。
代码写完在配置文件中添加一下拦截器。
<interceptors>
<!-- 设置打印action拦截器 -->
<interceptor name="systemOutPrint"class="com.**.**.**.SystemOutPrint"></interceptor>
<!-- 设置拦截器栈 -->
<interceptor-stackname="session">
<!-- 引用打印action拦截器 -->
<interceptor-refname="systemOutPrint"></interceptor-ref>
<!-- 引用struts2的默认拦截器栈 -->
<interceptor-refname="defaultStack"></interceptor-ref>
</interceptor-stack>
</interceptors>
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息