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

在一般的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>


  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值