spring aop注解(没有学Spring,可以直接学Spring boot吗)
本文目录
- 没有学Spring,可以直接学Spring boot吗
- spring mvc aop注解切入点
- spring 中的AOP是怎么实现的
- spring 用注解实现aop ,如何获取目标对象
- 如何利用Spring编写一个aop的例子
- spring aop 注解 通过 jdk实现的吗
- spring实现aop的注解有哪些
- spring aop 用什么实现
- JAVA-Spring注解实现AOP权限拦截,如何取得方法上自定义Annotation的值呢
没有学Spring,可以直接学Spring boot吗
这个还真可以,springboot追求的就是轻(无)配置,易部署,集成化,springboot内置了tomcat和jetty,只需要几行代码就可以实现一个简单的web服务!
而如果要只用spring实现一个web服务,将会有略显繁杂的配置,还要将应用打成war包放到tomcat中运行,过程比较繁琐!
但如果深入来看,springboot就是对spring进行再封装了一层,在启动类中完成了配置,底层的思想还是spring的,比如bean的扫描,注册,注解的解析处理,上下文的封装,aop等等都还是依赖于spring,换句话说spring是springboot的核心!
在这儿不得不提一下springCloud,虽然springboot提供了一套成熟的,可供快速开发的架构,我们可以使用它来快速搭建起服务,但是springboot只是一套简单的基础架构,比如服务的注册与发现,监控,安全认证等一系列企业级应用常遇到的问题,并不能使用springboot解决,而springCloud就是一套成熟的企业级框架,不仅提供了服务注册与发现,监控,还有网关,断路器,服务调用链,分布式配置中心等等一系列解决方案!
所以,最好的学习顺序应该是spring到springboot再到springcloud,才能准确的使用好spring生态!
我使用springCloud三年了,真的是比较好用的微服务框架,推荐大家使用!如果有问题,可以关注交流。。
spring mvc aop注解切入点
不太明白你的意思。spring AOP有2种方法来实现切入点。
1。用@注解方式 直接开启事务(用起来比较方便)
2。用默认配置文件方式(。xml))(正规大项目 都采用第二种方法,因为这样统一,还可观)
希望对你有所帮助
spring 中的AOP是怎么实现的
1使用ProxyFactoryBean的代理
2隐式使用ProxyFactoryBean的aop代理
DefaultAdvisorAutoProxyCreator实现了BeanPostProcessor,它将自动检查advisor的pointcut是否匹配bean的方法,如果匹配会替换bean为一个proxy,并且应用其advice。
3使用注解的aop代理
xml中增加了一个《aop:aspectj-autoproxy /》,它创建了AnnotationAwareAspectJAutoProxyCreator在spring中,这个类将自动代理匹配的类的放方法。和上个例子中DefaultAdvisorAutoProxyCreator做同样的工作。
4使用aop配置文件的自动代理采用这种方法,不用加《aop:aspectj-autoproxy /》
spring 用注解实现aop ,如何获取目标对象
在方法参数加一个JoinPoint
例如public void doBefore(JoinPoint jp) {
Object o = jp.getTarget();`//这个方法可以拿到目标对象
}
如何利用Spring编写一个aop的例子
打开Eclipse,新建Demo工程供编写测试程序使用。
导入编写测试程序使用到jar包。
注意:使用注解方式,必须引入aspectjrt和aspectjweaver包。
下面万事俱备,只欠东风了。开始编写测试程序。编写测试使用的接口类EatInter。
编写接口实现类,实现接口中的方法。
编写aop的通知类,此部分可以看作为公共模块要实现的功能。
修改Spring的applicationContext.xml配置文件。可以看到使用注解方式时,配置文件是非常简洁的。只需要编写红框中的代码即可。
做完以上工作后,我们可以编写测试用的主类了。执行以下主类,查看测试结果。此时可以看到通知类中的公共代码也全部执行。
spring aop 注解 通过 jdk实现的吗
AOP是OOP的延续,是Aspect Oriented Programming的缩写,意思是面向切面编程。可以通过预编译方式和运行期动态代理实现在不修改源代码的情况下给程序动态统一添加功能的一种技术。
AOP实际是GoF设计模式的延续,设计模式孜孜不倦追求的是调用者和被调用者之间的解耦,AOP可以说也是这种目标的一种实现。
spring实现aop的注解有哪些
在方法参数加一个JoinPoint 例如public void doBefore(JoinPoint jp) { Object o = jp.getTarget();`//这个方法可以拿到目标对象 }
spring aop 用什么实现
前面在学习代理模式的时候,了解到代理模式分为动态代理和静态代理。现在我们就以代理模式为基础先实现我们自己的AOP框架,再来研究Spring的AOP的实现原理。
先以静态代理实现,静态代理关键是在代理对象和目标对象实现共同的接口,并且代理对象持有目标对象的引用。
公共接口代码:
1 public interface IHello {2 /**3 * 业务方法4 * @param str5 */6 void sayHello(String str);7 }
目标类代码:
1 public class Hello implements IHello{2 @Override3 public void sayHello(String str) {4 System.out.println(“hello “+str);5 }6 7 }
代理类代码,我们给它添加日志记录功能,在方法开始前后执行特定的方法,是不是和AOP特别像呢?
public class ProxyHello implements IHello{
private IHello hello;
public ProxyHello(IHello hello) { super(); this.hello = hello;
}
@Override public void sayHello(String str) {
Logger.start();//添加特定的方法 hello.sayHello(str);
Logger.end();
}
}
日志类代码:
1 public class Logger {2 public static void start(){3 System.out.println(new Date()+ “ say hello start...“);4 }5 6 public static void end(){7 System.out.println(new Date()+ “ say hello end“);8 }9 }
测试代码:
1 public class Test {2 public static void main(String args) {3 IHello hello = new ProxyHello(new Hello());//如果我们需要日志功能,则使用代理类4 //IHello hello = new Hello();//如果我们不需要日志功能则使用目标类5 hello.sayHello(“明天“);
6 }7 }
这样我们就实现了一个最简单的AOP,但是这样会存在一个问题:如果我们像Hello这样的类很多,那么,我们是不是要去写很多个HelloProxy这样的类呢。其实也是一种很麻烦的事。在jdk1.3以后,jdk跟我们提供了一个API java.lang.reflect.InvocationHandler的类, 这个类可以让我们在JVM调用某个类的方法时动态的为些方法做些什么事。下面我们就来实现动态代理的实现。
动态代理实现主要是实现InvocationHandler,并且将目标对象注入到代理对象中,利用反射机制来执行目标对象的方法。
接口实现与静态代理相同,代理类代码:
1 public class DynaProxyHello implements InvocationHandler{ 2 3 private Object target;//目标对象 4 /** 5 * 通过反射来实例化目标对象 6 * @param object 7 * @return 8 */ 9 public Object bind(Object object){10 this.target = object;11 return Proxy.newProxyInstance(this.target.getClass().getClassLoader(), this.target.getClass().getInterfaces(), this);12 }13 14 @Override15 public Object invoke(Object proxy, Method method, Object args)16 throws Throwable {17 Object result = null;18 Logger.start();//添加额外的方法19 //通过反射机制来运行目标对象的方法20 result = method.invoke(this.target, args);21 Logger.end();22 return result;23 }24 25 }
测试类代码:
1 public class DynaTest {2 public static void main(String args) {3 IHello hello = (IHello) new DynaProxyHello().bind(new Hello());//如果我们需要日志功能,则使用代理类4 //IHello hello = new Hello();//如果我们不需要日志功能则使用目标类5 hello.sayHello(“明天“);6 }7 }
看完上面的代码可能和Spring AOP相比有一个问题,日志类只能在方法前后打印,但是AOP应该是可以在满足条件就可以执行,所有是否可以将DynaPoxyHello对象和日志操作对象(Logger)解耦呢?
看下面代码实现,将将DynaPoxyHello对象和日志操作对象(Logger)解耦:
我们要在被代理对象的方法前面或者后面去加上日志操作代码(或者是其它操作的代码),那么,我们可以抽象出一个接口,这个接口里就只有两个方法:一个是在被代理对象要执行方法之前执行的方法,我们取名为start,第二个方法就是在被代理对象执行方法之后执行的方法,我们取名为end。
Logger的接口:
1 public interface ILogger {2 void start(Method method);3 void end(Method method);4 }
Logger的接口实现:
1 public class DLogger implements ILogger{ 2 @Override 3 public void start(Method method) { 4 System.out.println(new Date()+ method.getName() + “ say hello start...“); 5 } 6 @Override 7 public void end(Method method) { 8 System.out.println(new Date()+ method.getName() + “ say hello end“); 9 }10 }
动态代理类:
1 public class DynaProxyHello1 implements InvocationHandler{ 2 //调用对象 3 private Object proxy; 4 //目标对象 5 private Object target; 6 7 public Object bind(Object target,Object proxy){ 8 this.target=target; 9 this.proxy=proxy;10 return Proxy.newProxyInstance(this.target.getClass().getClassLoader(), this.target.getClass().getInterfaces(), this);11 }12 13 14 @Override15 public Object invoke(Object proxy, Method method, Object args)16 throws Throwable {17 Object result = null;18 //反射得到操作者的实例19 Class clazz = this.proxy.getClass();20 //反射得到操作者的Start方法21 Method start = clazz.getDeclaredMethod(“start“, new Class{Method.class});22 //反射执行start方法23 start.invoke(this.proxy, new Object{this.proxy.getClass()});24 //执行要处理对象的原本方法25 method.invoke(this.target, args);26 //反射得到操作者的end方法27 Method end = clazz.getDeclaredMethod(“end“, new Class{Method.class});28 //反射执行end方法29 end.invoke(this.proxy, new Object{method});30 return result;31 }32 33 }
测试代码:
1 public class DynaTest1 {2 public static void main(String args) {3 IHello hello = (IHello) new DynaProxyHello1().bind(new Hello(),new DLogger());//如果我们需要日志功能,则使用代理类4 //IHello hello = new Hello();//如果我们不需要日志功能则使用目标类5 hello.sayHello(“明天“);6 }7 }
通过上面例子,可以发现通过动态代理和发射技术,已经基本实现了AOP的功能,如果我们只需要在方法执行前打印日志,则可以不实现end()方法,这样就可以控制打印的时机了。如果我们想让指定的方法打印日志,我们只需要在invoke()方法中加一个对method名字的判断,method的名字可以写在xml文件中,这样我们就可以实现以配置文件进行解耦了,这样我们就实现了一个简单的spring aop框架。
JAVA-Spring注解实现AOP权限拦截,如何取得方法上自定义Annotation的值呢
import java.lang.annotation.Retention;
import java.lang.annotation.RetentionPolicy;
import java.lang.reflect.InvocationTargetException;
import java.lang.reflect.Method;
@Retention(RetentionPolicy.RUNTIME)
@interface GetView {
String Method();
String Value();
}
public class Temp {
@GetView(Method = “aa“, Value = “bb“)
public void test() {
System.out.println(“In test method.“);
}
public static void main(String args) throws ClassNotFoundException, IllegalArgumentException, IllegalAccessException, InvocationTargetException, SecurityException, NoSuchMethodException {
Temp temp = new Temp();
Method method = temp.getClass().getMethod(“test“);
System.out.println(method.isAnnotationPresent(GetView.class));
method.invoke(temp);
GetView view = method.getAnnotation(GetView.class);
System.out.println(view.Method());
System.out.println(view.Value());
}
}
更多文章:
microsoft+edge打开老是跳转到360主页(edge浏览器打开是360怎么办)
2024年7月24日 06:51
求可以三四个人玩的魔兽防守地图?这个游戏叫什么名字(关于三国的老游戏)
2024年7月10日 11:08
oppo手机一键root(OPPO手机怎么一键root权限)
2024年7月13日 16:13
火影忍者终极战斗(火影忍者疾风传最终的大结局的什么鸣人打的最终BOSS是谁)
2024年6月3日 19:03
我用全屏助手突然不能用了怎么办?andriod 全屏助手怎么用
2024年5月9日 11:49
卓大师刷机官方下载(步步高vivo s7使用卓大师一键root)
2024年7月16日 07:03
下载ie10浏览器最新版本(苹果手机怎么下载ie6-ie10系列浏览器)
2024年5月6日 17:30