1.自定义注解:
@Target({ ElementType.PARAMETER, ElementType.METHOD })
@Retention(RetentionPolicy.RUNTIME)
@Documented
public @interface View {
public String value() default "";
/**
* 功能,不同的操作类型
*/
public BusinessType businessType() default BusinessType.VIEW;
}
2.编写切面类:
@Aspect
@Component
@Slf4j
public class FrontViewAspect {
@Autowired
private IStatisticsOperLogService statisticsOperLogService;
@Autowired
private FrontUtils frontUtils;
@Resource
private OperRedisUtil operRedisUtil;
@Autowired
private HttpServletRequest request;
//定义切点 @Pointcut
//在注解的位置切入代码
@Pointcut("@annotation(tech.niua.front.annotation.View)")
public void viewPoinCut() {
}
//切面 配置通知
@AfterReturning("viewPoinCut()")
public void saveSysLog(JoinPoint joinPoint) {
log.info("进入前端网页访问统计---start----");
//保存浏览记录
StatisticsOperLog statisticsOperLog = new StatisticsOperLog();
//从切面织入点处通过反射机制获取织入点处的方法
MethodSignature signature = (MethodSignature) joinPoint.getSignature();
//获取切入点所在的方法
Method method = signature.getMethod();
Site site = frontUtils.loadSite();
//调用工具类向redis中更新访问数据同时获取用户uuid
String uuid = operRedisUtil.setData(request,response,site.getId());
//获取操作
View view = method.getAnnotation(View.class);
if (view != null) {
String value = view.value();
statisticsOperLog.setOperation(value);//保存获取的操作
}
statisticsOperLog.setSiteId(site.getId());
//获取请求路径
String path = request.getRequestURL().toString();
statisticsOperLog.setPath(path);
statisticsOperLog.setCookieUuid(uuid);
statisticsOperLog.setIp(IpUtil.getIpAddr(request));
statisticsOperLog.setBusinessType(view.businessType().toString());
statisticsOperLogService.save(statisticsOperLog);
}
}
这样就编写成功一个切面
在需要的方法上使用自己定义的注解就会执行切面类中的代码,从而达到记录的效果