利用Struts2拦截器实现 db日志

来源:百度知道 编辑:UC知道 时间:2024/06/17 19:02:06
刚刚学习SSH,自己做了个小项目,要实现操作的日志记录,想利用Struts2的拦截器实现,但是不知道怎么实现,是对每一个Action写一个拦截器还是对所有的方法写一个拦截器,要是对所有的方法都对应一个拦截器的话,那不是在这个拦截器里进行N多的if语句判断,然后再对每一个方法进行处理,最后插入到数据库中去。感觉这样多不是怎么好。
还有人说用Spring的AOP实现,一个切面只能够对应一类Action进行处理,但是我希望每一个Action有不同的处理方法。希望高手指点。
看有人说可以“将各个acton及对应的方法及操作等都可以进行配置,如配置到一个xml文件当中,以后系统中新增加了action去修改xml文件就可以了。这样就不用去写大量的if,也不用每次有新增action来改日志管理系统的代码了。”
不知道这个怎么实现。请有经验者指点。能上我解决者在加100分。
我知道用Log4j实现DB日志,但是他只能够实现一种日志,我的系统要求有多种日志,比如说普通用户日志,只能看到他自己的日志,还有管理员日志,如果单用Log4j不能实现,所以才采用拦截器。

是对每一个Action写一个拦截器还是对所有的方法写一个拦截器.显然是后者。如果是前者,一个action对应一个拦截器还不如直接在action里面写呢。

拦截器只能完成一些通用的功能。比如进入简单的日志,什么时候进入调用了那个类,那个方法,,都有哪写参数,有没有异常,request中的一些参数,这些是拦截器可以做的。

但是如果你的日志中包含了业务信息,那么只能在action内做。

实现日志记录我们一般不使用拦截器,而是用org.apache.log4j.Logger这个包来记录的,在每个DAO处理中都用logger来记录你的增删改查记录
拦截器一般用于普遍性的动作,验证每个试图访问后台action动作,如登陆验证,字符乱码处理等

不需要业务信息的话,可以写通用的日志拦截类,大体记录的日志如下:
某时间某人操作了某类的某方法(IP地址等也可以记录)

如果涉及到业务信息的话,只能在action中写了,例如:
某人修改了原名为XXX的记录,改为XXXX

11