【Aspect】Sprignboot中 面向Aop 自定义编程
温馨提示:
本文最后更新于 2018年11月15日,已超过 2,192 天没有更新。若文章内的图片失效(无法正常加载),请留言反馈或直接联系我。
Springboot中如何自定义面向切面?
切面接口类
@Target({ElementType.METHOD})
@Retention(RetentionPolicy.RUNTIME)
public @interface BussinessLog {
/**
* 业务的名称
*/
String value() default "";
/**
* 平台,默认为后台管理
*/
PlatformEnum platform() default PlatformEnum.ADMIN;
/**
* 是否将当前日志记录到数据库中
*/
boolean save() default true;
}
切面接口实现
@Slf4j
@Aspect
@Component
public class BussinessLogAspect {
@Autowired
private SysLogService logService;
@Pointcut(value = "@annotation(com.zyd.blog.business.annotation.BussinessLog)")
public void pointcut() {
}
@Around("pointcut()")
public Object writeLog(ProceedingJoinPoint point) throws Throwable {
//先执行业务
Object result = point.proceed();
try {
handle(point);
} catch (Exception e) {
log.error("日志记录出错!", e);
}
return result;
}
}
主方法启动注解:
@RequestMapping("/")
@BussinessLog(value = "进入首页", platform = PlatformEnum.WEB)
public ModelAndView home(ArticleConditionVO vo, Model model) {
model.addAttribute("url", INDEX_URL);
loadIndexPage(vo, model);
return ResultUtil.view(INDEX_URL);
}
只要添加注解 @BussinessLog(value = "进入首页", platform = PlatformEnum.WEB) 即可
正文到此结束
- 本文标签: Spring Boot
- 本文链接: http://www.unknowtime.top/article/20
- 版权声明: 本文由仓颉大哥原创发布,转载请遵循《署名-非商业性使用-相同方式共享 4.0 国际 (CC BY-NC-SA 4.0)》许可协议授权