Linux安全网 - Linux操作系统_Linux 命令_Linux教程_Linux黑客

会员投稿 投稿指南 本期推荐:
搜索:
您的位置: Linux安全网 > Linux集群 > Architecture > » 正文

tomcat应用中使用aspectj输出服务器端的访问日志

来源: 未知 分享至:

想在web应用的服务器端避免编写太多一样的日志输出代码。我们一般采用aop技术,现在比较流行的是在sping中配置aop功能,网上很多相关资料。在不使用spring等容器注入技术的情况下,我们一般采用aspectj技术。
在此我分享一下采用aspectj输出日志时的运行环境和开发环境的配置。

下载相关包


aspectj的核心包 http://eclipse.org/aspectj/downloads.php 下载后解压缩,在目录中有aspectjrt.jar,aspectjweaver.jar(还有一些其他的,我们暂时只用这两个)
eclipse插件(ajdt) http://www.eclipse.org/ajdt/downloads/ 下载与eclipse相配的ajdt

我使用的开发环境:
eclipse3.7
tomcat6.0.18
jdk1.6.12

配置开发环境
1,将下载的ajdt作为插件加入到eclipse中。
2,将aspectjrt.jar加到工程的库里面。
3,在tomcat的JVM设置中加入如下配置。


-javaagent:"C:\JAVA\APPServer\Tomcat\apache-tomcat-6.0.18\lib\aspectjweaver.jar"

为上面下载的aspectjweaver.jar的绝对路径。
4,编写aop.xml(文件名固定)


<?xml version="1.0" encoding="UTF-8"?>
<aspectj>
  <aspects>
  <concrete-aspect name="com.test.framework.aspect._Smsf_Aspect" 
   extends="com.test.framework.aspect.AbstractAspect">
   <pointcut name="runAccess" 
     expression="
execution(* com.test.framework.web.action.*.*(..)) ||
execution(* com.test.demo.web.handle.*.*(..)) ||
execution(* com.test.demo.dao.impl.*.*(..))"/>
     </concrete-aspect>
    </aspects>
</aspectj>

其中的name属性是一个由系统自动产生的类,不需要特意创建。


5,将aop.xml配置到java的/src/META-INF/中,确保编译后的路径为:WEB-INF/classes/META-INF/aop.xml.


6,编写步骤4中extends制定的虚拟类。


@Aspect
public abstract class AbstractAspect {
	// abstract pointcut: no expression is defined
    @Pointcut
    abstract void runAccess();

    @Before("runAccess()")
    public void before(JoinPoint jp) {
    	LogLogic.writeMethodStartlog(jp);
    }
    
    @After("runAccess()")
    public void after(JoinPoint jp) {
    	LogLogic.writeMethodEndlog(jp);
    }

}

7,运行代码。



配置运行环境
在开发环境中打好的war包放在web服务器(tomcat)中运行时,我们只需将启动tomcat的java命令中加上步骤3中所述的参数。


更改catalina.bat文件的JAVA_OPTS属性:
set JAVA_OPTS=%JAVA_OPTS% -javaagent:"C:\JAVA\APPServer\Tomcat\apache-tomcat-6.0.18\lib\aspectjweaver.jar"

用startup.bat启动服务器即可。


Tags:
分享至:
最新图文资讯
1 2 3 4 5 6
验证码:点击我更换图片 理智评论文明上网,拒绝恶意谩骂 用户名:
关于我们 - 联系我们 - 广告服务 - 友情链接 - 网站地图 - 版权声明 - 发展历史