SpringBoot之切面AOP
SpringBoot提供了强大AOP支持,我们前面讲解过AOP面向切面,所以这里具体AOP原理就补具体介绍;
AOP切面主要是切方法,我们一般搞一些日志分析和事务操作,要用到切面,类似拦截器;
@Aspect注解是切面注解类
@Pointcut切点定义
@Before是方法执行前调用
@After是方法执行后调用
@AfterReturning方法执行返回值调用
Service层本身就可以切入事务,所以我们这类搞个常用的 切controller层方法
每个执行controller层的方法 都记录下请求Url,访问者IP 执行类方法参数等信息;
定义一个切面类:RequestAspect
| 
 1 
2 
3 
4 
5 
6 
7 
8 
9 
10 
11 
12 
13 
14 
15 
16 
17 
18 
19 
20 
21 
22 
23 
24 
25 
26 
27 
28 
29 
30 
31 
32 
33 
34 
35 
36 
37 
38 
39 
40 
41 
42 
43 
44 
45 
46 
47 
 | 
package com.java1234.aspect;import javax.servlet.http.HttpServletRequest;import org.apache.log4j.Logger;import org.aspectj.lang.JoinPoint;import org.aspectj.lang.annotation.After;import org.aspectj.lang.annotation.AfterReturning;import org.aspectj.lang.annotation.Aspect;import org.aspectj.lang.annotation.Before;import org.aspectj.lang.annotation.Pointcut;import org.springframework.stereotype.Component;import org.springframework.web.context.request.RequestContextHolder;import org.springframework.web.context.request.ServletRequestAttributes;@Aspect@Componentpublic class RequestAspect {      private Logger logger=Logger.getLogger(RequestAspect.class);         @Pointcut("execution(public * com.java1234.controller.*.*(..))")    public void log(){    }         @Before("log()")    public void deoBefore(JoinPoint joinPoint){        logger.info("方法执行前...");        ServletRequestAttributes sra=(ServletRequestAttributes) RequestContextHolder.getRequestAttributes();        HttpServletRequest request=sra.getRequest();        logger.info("url:"+request.getRequestURI());        logger.info("ip:"+request.getRemoteHost());        logger.info("method:"+request.getMethod());        logger.info("class_method:"+joinPoint.getSignature().getDeclaringTypeName()+"."+joinPoint.getSignature().getName());        logger.info("args:"+joinPoint.getArgs());    }         @After("log()")    public void doAfter(JoinPoint joinPoint){        logger.info("方法执行后...");    }         @AfterReturning(returning="result",pointcut="log()")    public void doAfterReturning(Object result){        logger.info("执行返回值:"+result);    }} | 
execution(public * com.java1234.controller.*.*(..)) 这个定义 意思是 对 com.java1234.controller包下的任意类,任意方法,任意参数,任意返回值的方法都进行切入
我们测试 StudentController
请求:http://localhost:8888/studentAdd.html

点击“提交”,
控制台显示:
2017-08-11 11:22:46.357 INFO 9896 --- [nio-8888-exec-9] com.java1234.aspect.RequestAspect : 方法执行前...
2017-08-11 11:22:46.358 INFO 9896 --- [nio-8888-exec-9] com.java1234.aspect.RequestAspect : url:/student/add
2017-08-11 11:22:46.358 INFO 9896 --- [nio-8888-exec-9] com.java1234.aspect.RequestAspect : ip:0:0:0:0:0:0:0:1
2017-08-11 11:22:46.358 INFO 9896 --- [nio-8888-exec-9] com.java1234.aspect.RequestAspect : method:POST
2017-08-11 11:22:46.358 INFO 9896 --- [nio-8888-exec-9] com.java1234.aspect.RequestAspect : class_method:com.java1234.controller.StudentController.add
2017-08-11 11:22:46.358 INFO 9896 --- [nio-8888-exec-9] com.java1234.aspect.RequestAspect : args:[Ljava.lang.Object;@fd1ee9
Hibernate: insert into t_student (age, name) values (?, ?)
2017-08-11 11:22:46.372 INFO 9896 --- [nio-8888-exec-9] com.java1234.aspect.RequestAspect : 方法执行后...
2017-08-11 11:22:46.373 INFO 9896 --- [nio-8888-exec-9] com.java1234.aspect.RequestAspect : 执行返回值:添加成功!
这里得到了我们需要的信息;
当然这里用到了日志 springboot推荐logback log4j的升级版 用法基本差不多;
SpringBoot之切面AOP的更多相关文章
- spring boot学习(8) SpringBoot 之切面AOP
		
在方法执行的前后,切入代码:经典的service层切入事务: @Aspect注解是切面注解类 @Pointcut切点定义 @Before是方法执行前调用 @After是方法执行后调用 @AfterRe ...
 - SpringBoot切面Aop的demo简单讲解
		
前言 本篇文章主要介绍的是SpringBoot切面Aop的demo简单讲解. SpringBoot Aop 说明:如果想直接获取工程那么可以直接跳到底部,通过链接下载工程代码. 切面(Aop) 一.概 ...
 - 在IDEA 、springboot中使用切面aop实现日志信息的记录到数据库
		
文章目录 1.导入相关的依赖 2.创建要保存的数据信息实体类 3 .编写对应的sql语句 4.使用spring 的 aop 技术切到自定义注解上,所以先创建一个自定义注解类 5. 创建aop切面实现类 ...
 - Springboot中使用AOP统一处理Web请求日志
		
title: Springboot中使用AOP统一处理Web请求日志 date: 2017-04-26 16:30:48 tags: ['Spring Boot','AOP'] categories: ...
 - SpringBoot图文教程5—SpringBoot 中使用Aop
		
有天上飞的概念,就要有落地的实现 概念+代码实现是本文的特点,教程将涵盖完整的图文教程,代码案例 文章结尾配套自测面试题,学完技术自我测试更扎实 概念十遍不如代码一遍,朋友,希望你把文中所有的代码案例 ...
 - 编写SpringBoot 中的AOP
		
编写SpringBoot 中的AOP 在程序开发的过程中会使用到AOP的思想,面向切面进行开发,比如登录的验证,记录日志等等-频繁需要操作的步骤,在遇到这种情况时就要使用Spring 的AOP了 Sp ...
 - Puzzle 面向服务/切面(AOP/IOC)开发框架 For .Net
		
Puzzle 面向服务/切面AOP开发框架 For .Net AOP主要实现的目的是针对业务处理过程中的切面进行提取,它所面对的是处理过程中的某个步骤或阶段,以获得逻辑过程中各部分之间低耦合性的隔离效 ...
 - Liferay7 BPM门户开发之36: 使用Portlet filters过滤器做切面AOP
		
使用Portlet filters过滤器做切面AOP Portlet Filters定义于JSR286 Java Portlet Specification 2.0 Portlet Filters是为 ...
 - 在SpringBoot中配置aop
		
前言 aop作为spring的一个强大的功能经常被使用,aop的应用场景有很多,但是实际的应用还是需要根据实际的业务来进行实现.这里就以打印日志作为例子,在SpringBoot中配置aop 已经加入我 ...
 
随机推荐
- IHostingEnvironment VS IHostEnvironment - .NET Core 3.0中的废弃类型
			
原文: https://andrewlock.net/ihostingenvironment-vs-ihost-environment-obsolete-types-in-net-core-3/ 作者 ...
 - FTP服务器红帽5.4搭建图文教程!!!
			
FTP服务器搭建 服务器的环境 红帽5.4 vm15 挂载光盘 mount mount -t iso9660 设备目录 /mnt 表示挂载 软件包安装 FTP服务器安装包命令: rpm -ivh /m ...
 - CS系列(一):Cobalt Strike初体验
			
0X01 环境准备 Cobalt Strike安装包(链接:https://pan.baidu.com/s/1wCHJcJrF6H0wUCdetz3Xjg 提取码:rjuj) Cobalt Strik ...
 - Vuex入门实践(中)-多module中的state、mutations、actions和getters
			
一.前言 上一篇文章<Vuex入门实践(上)>,我们一共实践了vuex的这些内容: 1.在state中定义共享属性,在组件中可使用[$store.state.属性名]访问共享属性 2.在m ...
 - POJ 2456 Aggressive cows (二分)
			
题目传送门 POJ 2456 Description Farmer John has built a new long barn, with N (2 <= N <= 100,000) s ...
 - txLive模块(直播类)试用分享
			
本文出自APICloud官方论坛, 感谢论坛版主uoaccw的分享. txLive 模块封装了腾讯云直播服务 https://docs.apicloud.com/Client-API/Open-SDK ...
 - cogs 2. 旅行计划 dijkstra+打印路径小技巧
			
2. 旅行计划 ★★ 输入文件:djs.in 输出文件:djs.out 简单对比时间限制:3 s 内存限制:128 MB [题目描述] 过暑假了,阿杜准备出行旅游,他已经查到了某些城市 ...
 - java类中元素初始化顺序
			
结论:对于静态变量.静态初始化块.变量.初始化块.构造器,它们的初始化顺序依次是(静态变量.静态初始化块)>(变量.初始化块)>构造器. public class Test4 { @Tes ...
 - 聊聊HTTP请求那一些事_HttpWebRequest_一篇就够了
			
最近工作比较忙,很久没有写东西了,今天抽点时间整体一下最近工作的一个知识点小结.http请求对我们来说一点都不模式,程序员的我们有可能天天就是和这一些打交道.无论是BS架构的程序,前后端的数据交互, ...
 - P1559 运动员最佳匹配问题 by hyl 天梦
			
#include<iostream> using namespace std; int n; int maxx[21][21]; int lie[21]; int aa[21]; int ...