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

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

[u][b]下载相关包[/b][/u]
[table]
|aspectj的核心包|http://eclipse.org/aspectj/downloads.php|下载后解压缩,在目录中有aspectjrt.jar,aspectjweaver.jar(还有一些其他的,我们暂时只用这两个)
|eclipse插件(ajdt)|http://www.eclipse.org/ajdt/downloads/|下载与eclipse相配的ajdt|
[/table]
我使用的开发环境:
eclipse3.7
tomcat6.0.18
jdk1.6.12

[u][b]配置开发环境[/b][/u]
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>

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


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,运行代码。


[u][b]配置运行环境[/b][/u]
在开发环境中打好的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启动服务器即可。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
以下是一个简单的Spring使用AspectJ的案例: 1. 定义切面类 ```java @Aspect @Component public class LoggingAspect { @Before("execution(* com.example.service.*.*(..))") public void logBefore(JoinPoint joinPoint) { System.out.println("Before " + joinPoint.getSignature().getName() + " method is called"); } @After("execution(* com.example.service.*.*(..))") public void logAfter(JoinPoint joinPoint) { System.out.println("After " + joinPoint.getSignature().getName() + " method is called"); } } ``` 上面的代码定义了一个切面类`LoggingAspect`,其包含了两个通知方法`logBefore`和`logAfter`,分别在目标方法执行前和执行后打印日志。 2. 配置Spring AOP ```xml <aop:aspectj-autoproxy /> <bean id="loggingAspect" class="com.example.aspect.LoggingAspect" /> ``` 在Spring配置文件加入以上两行配置,启用AspectJ自动代理和定义切面类。 3. 使用切面 ```java @Service public class UserServiceImpl implements UserService { @Override public User getUserById(int id) { System.out.println("getUserById(" + id + ")"); return new User(id, "John"); } @Override public void saveUser(User user) { System.out.println("saveUser(" + user + ")"); } } ``` 在目标类`UserServiceImpl`的方法上不需要添加任何注解或配置,AspectJ会自动将切面织入到这些方法。 4. 测试 ```java public class Application { public static void main(String[] args) { ApplicationContext context = new ClassPathXmlApplicationContext("applicationContext.xml"); UserService userService = context.getBean(UserService.class); userService.getUserById(1); userService.saveUser(new User(2, "Alice")); } } ``` 运行上面的代码,可以看到控制台输出: ``` Before getUserById method is called getUserById(1) After getUserById method is called Before saveUser method is called saveUser(User [id=2, name=Alice]) After saveUser method is called ``` 这表明切面已经成功织入到了目标方法

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值