JSP 自定义注解及记录操作日志

发布时间 - 2026-01-11 01:16:26    点击率:

JSP 自定义注解及记录操作日志

Spring的配置文件

<aop:aspectj-autoproxy />

日志拦截器

package com.vem.interceptor;

import org.aspectj.lang.ProceedingJoinPoint;
import org.aspectj.lang.annotation.Around; 
import org.aspectj.lang.annotation.Aspect; 
import org.aspectj.lang.annotation.Pointcut;
import org.aspectj.lang.reflect.MethodSignature;
import org.springframework.stereotype.Component;

import com.vem.entity.BussAnnotation; 

@Aspect 
@Component 
public class LogInterceptor { 
 
 
  @Pointcut("execution(* com.vem.service..*.*(..))") 
  public void aApplogic() { 
   
  } 
   
  /** 
   * 环绕通知 用于拦截指定内容,记录用户的操作 
   */ 
  @Around(value = "aApplogic() && @annotation(annotation) &&args(object,..) ", argNames = "annotation,object") 
  public void interceptorApplogic(ProceedingJoinPoint joinPoint, 
      BussAnnotation annotation, Object object) throws Throwable { 
    System.out.println("模块名称moduleName:" + annotation.moduleName()); 
    System.out.println("操作名称option:" + annotation.option()); 
    String methodName = joinPoint.getSignature().getName();
 System.out.println("方法名methodName:" + methodName); 
    
    MethodSignature methodSignature = (MethodSignature) joinPoint.getSignature(); 
    String[] strings = methodSignature.getParameterNames(); 
    
    joinPoint.proceed(); 
    
    Object[] arguments = joinPoint.getArgs();  //获得参数列表
    if(arguments.length<=0){ 
      System.out.println(methodName+"方法没有参数"); 
    }else{ 
     for(int i=0;i<arguments.length;i++){ 
     System.out.println(strings[i]+" : "+arguments[i]+" : ");
     } 
    } 
  } 
} 

自定义注解

@Retention(RetentionPolicy.RUNTIME) 
@Target({ElementType.METHOD}) 
@Documented 
public @interface BussAnnotation { 
  //模块名 
  String moduleName() default ""; 
  //操作内容 
  String option() default ""; 
} 

接口实现

写在service

@BussAnnotation(moduleName="人员管理",option="添加用户") 
public void testDemo1(PageData pd) throws Exception{
 
}

junit测试类

package com.vem.entity;

import javax.annotation.Resource;

import org.junit.Test; 
import org.junit.runner.RunWith; 
import org.springframework.test.context.ContextConfiguration; 
import org.springframework.test.context.junit4.SpringJUnit4ClassRunner;

import com.vem.service.data.DemoService;
import com.vem.util.PageData; 
 
@RunWith(SpringJUnit4ClassRunner.class) 
@ContextConfiguration(
 {"classpath:spring/ApplicationContext.xml"
 })
public class AopTest { 
 
 @Resource(name = "demoService")
 public DemoService demoService;
  
  @Test 
  public void testAopAddUser1(){ 
   PageData pd = new PageData();
   pd.put("name", "zhangzexing");
   pd.put("age", "21");
   pd.put("passward", "123456");
   try {
  demoService.testDemo2(pd);
 } catch (Exception e) {
  // TODO Auto-generated catch block
  e.printStackTrace();
 }
  } 

} 
 

感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!


# JSP  # 自定义注解及记录操作日志  # 自定义注解和操作日志  # 详解springmvc 中controller与jsp传值  # springMVC如何将controller中数据传递到jsp页面  # JSP spring boot / cloud 使用filter防止XSS  # JSP 获取spring容器中bean的两种方法总结  # 利用JSP session对象保持住登录状态  # JSP 开发之 releaseSession的实例详解  # 自定义  # 希望能  # 谢谢大家  # 写在  # 配置文件  # 拦截器  # amp  # aApplogic  # argNames  # object  # args  # public  # BussAnnotation  # entity  # LogInterceptor  # void  # service  # execution  # String  # option 


相关栏目: 【 网站优化151355 】 【 网络推广146373 】 【 网络技术251813 】 【 AI营销90571


相关推荐: Laravel如何使用Contracts(契约)进行编程_Laravel契约接口与依赖反转  Laravel如何生成和使用数据填充?(Seeder和Factory示例)  Bootstrap整体框架之JavaScript插件架构  Laravel怎么实现模型属性的自动加密  Laravel路由怎么定义_Laravel核心路由系统完全入门指南  微信小程序制作网站有哪些,微信小程序需要做网站吗?  Laravel怎么多语言本地化设置_Laravel语言包翻译与Locale动态切换【手册】  如何使用 Go 正则表达式精准提取括号内首个纯字母标识符(忽略数字与嵌套)  Laravel如何生成API文档?(Swagger/OpenAPI教程)  Python文件异常处理策略_健壮性说明【指导】  香港服务器网站搭建教程-电商部署、配置优化与安全稳定指南  网站页面设计需要考虑到这些问题  绝密ChatGPT指令:手把手教你生成HR无法拒绝的求职信  Laravel怎么做数据加密_Laravel内置Crypt门面的加密与解密功能  VIVO手机上del键无效OnKeyListener不响应的原因及解决方法  IOS倒计时设置UIButton标题title的抖动问题  移动端脚本框架Hammer.js  香港代理服务器配置指南:高匿IP选择、跨境加速与SEO优化技巧  JS去除重复并统计数量的实现方法  千问怎样用提示词获取健康建议_千问健康类提示词注意事项【指南】  Laravel如何理解并使用服务容器(Service Container)_Laravel依赖注入与容器绑定说明  详解Android图表 MPAndroidChart折线图  JavaScript如何实现音频处理_Web Audio API如何工作?  Laravel怎么使用artisan命令缓存配置和视图  Python文件流缓冲机制_IO性能解析【教程】  Laravel怎么实现支付功能_Laravel集成支付宝微信支付  JavaScript如何实现类型判断_typeof和instanceof有什么区别  Laravel集合Collection怎么用_Laravel集合常用函数详解  微信小程序 input输入框控件详解及实例(多种示例)  Laravel全局作用域是什么_Laravel Eloquent Global Scopes应用指南  详解Android中Activity的四大启动模式实验简述  Laravel如何记录日志_Laravel Logging系统配置与自定义日志通道  Laravel如何配置和使用缓存?(Redis代码示例)  怎么制作一个起泡网,水泡粪全漏粪育肥舍冬季氨气超过25ppm,可以有哪些措施降低舍内氨气水平?  Laravel怎么调用外部API_Laravel Http Client客户端使用  如何快速生成凡客建站的专业级图册?  Laravel distinct去重查询_Laravel Eloquent去重方法  laravel怎么为应用开启和关闭维护模式_laravel应用维护模式开启与关闭方法  详解Huffman编码算法之Java实现  专业企业网站设计制作公司,如何理解商贸企业的统一配送和分销网络建设?  javascript读取文本节点方法小结  Laravel如何设置定时任务(Cron Job)_Laravel调度器与任务计划配置  js实现获取鼠标当前的位置  如何快速上传建站程序避免常见错误?  在线制作视频网站免费,都有哪些好的动漫网站?  jquery插件bootstrapValidator表单验证详解  魔方云NAT建站如何实现端口转发?  网站制作价目表怎么做,珍爱网婚介费用多少?  javascript中的try catch异常捕获机制用法分析  最好的网站制作公司,网购哪个网站口碑最好,推荐几个?谢谢?