长沙网站建设企业,网站自己做服务器划算吗,凡科建站怎么导出网页,牛商网营销型网站建设目录Spring核心知识SpringAOP原理AOP编程技术什么是AOP编程AOP底层实现原理AOP编程使用Spring核心知识Spring是一个开源框架#xff0c;Spring是于2003年兴起的一个轻量级的Java开发框架#xff0c;由Rod Johnson在其著作Expert One-On-One J2EE Development and Design中阐述…目录Spring核心知识SpringAOP原理AOP编程技术什么是AOP编程AOP底层实现原理AOP编程使用Spring核心知识Spring是一个开源框架Spring是于2003年兴起的一个轻量级的Java开发框架由Rod Johnson在其著作Expert One-On-One J2EE Development and Design中阐述的部分理念和原型衍生而来。它是为了解决企业应用开发的复杂性而创建的。框架的主要优势之一就是其分层架构分层架构允许使用者选择使用哪一个组件同时为J2EE应用程序开发提供集成的框架。Spring使用基本的JavaBean来完成以前只可能由EJB完成的事情。然而Spring的用途不仅限于服务器端的开发。从简单性、可测试性和松耦合的角度而言任何Java应用都可以从Spring中受益。Spring的核心是控制反转(IoC)和面向切面(AOP)。简单来说Spring是一个分层的JavaSE/EEfull-stack(一站式)轻量级开源框架。为什么说Spring是一个一站式的轻量级开源框架呢EE开发可分成三层架构针对JavaEE的三层结构每一层Spring都提供了不同的解决技术。• WEB层SpringMVC• 业务层Spring的IoC• 持久层Spring的JDBCTemplate(Spring的JDBC模板ORM模板用于整合其他的持久层框架)从上面的简要介绍中我们要知道Spring的核心有两部分• IoC控制反转。举例来说在之前的操作中比方说有一个类我们想要调用类里面的方法(不是静态方法)就要创建类的对象使用对象调用方法实现。对于Spring来说Spring创建对象的过程不是在代码里面实现的而是交给Spring来进行配置实现的。AOP面向切面编程。SpringAOP原理AOP编程技术什么是AOP编程AOP: Aspect Oriented Programming 面向切面编程。 面向切面编程(也叫面向方面)Aspect Oriented Programming(AOP),是目前软件开发中的一个热点。利用AOP可以对业务逻辑的各个部分进行隔离从而使得业务逻辑各部分之间的耦合度降低提高程序的可重用性同时提高了开发的效率。 AOP是OOP的延续是(Aspect Oriented Programming)的缩写意思是面向切面(方面)编程。 主要的功能是日志记录性能统计安全控制事务处理异常处理等等。 主要的意图是将日志记录性能统计安全控制事务处理异常处理等代码从业务逻辑代码中划分出来通过对这些行为的分离我们希望可以将它们独立到非指导业务逻辑的方法中进而改 变这些行为的时候不影响业务逻辑的代码。可以通过预编译方式和运行期动态代理实现在不修改源代码的情况下给程序动态统一添加功能的一种技术。AOP实际是GoF设计模式的延续设计模式孜孜不倦追求的是调用者和被调用者之间的解耦AOP可以说也是这种目标的一种实现。假设把应用程序想成一个立体结构的话OOP的利刃是纵向切入系统把系统划分为很多个模块(如用户模块文章模块等等)而AOP的利刃是横向切入系统提取各个模块可能都要重复操作的部分(如权限检查日志记录等等)。由此可见AOP是OOP的一个有效补充。注意AOP不是一种技术实际上是编程思想。凡是符合AOP思想的技术都可以看成是AOP的实现。Aop aspect object programming 面向切面编程功能 让关注点代码与业务代码分离关注点关注点,重复代码就叫做关注点切面关注点形成的类就叫切面(类)面向切面编程就是指 对很多功能都有的重复的代码抽取再在运行的时候网业务方法上动态植入“切面类代码”。切入点执行目标对象方法动态植入切面代码。可以通过切入点表达式指定拦截哪些类的哪些方法 给指定的类在运行的时候植入切面类代码。AOP底层实现原理代理设计模式什么是代理模式通过代理控制对象的访问,可以详细访问某个对象的方法在这个方法调用处理或调用后处理。既(AOP微实现) ,AOP核心技术面向切面编程。代理模式应用场景SpringAOP、事物原理、日志打印、权限控制、远程调用、安全代理 可以隐蔽真实角色代理的分类静态代理(静态定义代理类)动态代理(动态生成代理类)Jdk自带动态代理Cglib 、javaassist(字节码操作库)静态代理什么是静态代理由程序员创建或工具生成代理类的源码再编译代理类。所谓静态也就是在程序运行前就已经存在代理类的字节码文件代理类和委托类的关系在运行前就确定了。静态代理代码public interface IUserDao { void save();}public class UserDao implements IUserDao { public void save() { System.out.println(已经保存数据...); }}代理类public class UserDaoProxy implements IUserDao { private IUserDao target; public UserDaoProxy(IUserDao iuserDao) { this.target iuserDao; } public void save() { System.out.println(开启事物...); target.save(); System.out.println(关闭事物...); }}动态代理什么是动态代理1.代理对象,不需要实现接口2.代理对象的生成,是利用JDK的API,动态的在内存中构建代理对象(需要我们指定创建代理对象/目标对象实现的接口的类型)3.动态代理也叫做:JDK代理,接口代理JDK动态代理1)原理是根据类加载器和接口创建代理类(此代理类是接口的实现类所以必须使用接口 面向接口生成代理位于java.lang.reflect包下)2)实现方式通过实现InvocationHandler接口创建自己的调用处理器 IvocationHandler handler new InvocationHandlerImpl(…);通过为Proxy类指定ClassLoader对象和一组interface创建动态代理类Class clazz Proxy.getProxyClass(classLoader,new Class[]{…});通过反射机制获取动态代理类的构造函数其参数类型是调用处理器接口类型Constructor constructor clazz.getConstructor(new Class[]{InvocationHandler.class});通过构造函数创建代理类实例此时需将调用处理器对象作为参数被传入Interface Proxy (Interface)constructor.newInstance(new Object[] (handler));缺点jdk动态代理必须是面向接口目标业务类必须实现接口// 每次生成动态代理类对象时,实现了InvocationHandler接口的调用处理器对象 public class InvocationHandlerImpl implements InvocationHandler { private Object target;// 这其实业务实现类对象用来调用具体的业务方法 // 通过构造函数传入目标对象 public InvocationHandlerImpl(Object target) { this.target target; } public Object invoke(Object proxy, Method method, Object[] args) throws Throwable { Object result null; System.out.println(调用开始处理); result method.invoke(target, args); System.out.println(调用结束处理); return result; } public static void main(String[] args) throws NoSuchMethodException, SecurityException, InstantiationException, IllegalAccessException, IllegalArgumentException, InvocationTargetException { // 被代理对象 IUserDao userDao new UserDao(); InvocationHandlerImpl invocationHandlerImpl new InvocationHandlerImpl(userDao); ClassLoader loader userDao.getClass().getClassLoader(); Class[] interfaces userDao.getClass().getInterfaces(); // 主要装载器、一组接口及调用处理动态代理实例 IUserDao newProxyInstance (IUserDao) Proxy.newProxyInstance(loader, interfaces, invocationHandlerImpl); newProxyInstance.save(); }}CGLIB动态代理原理利用asm开源包对代理对象类的class文件加载进来通过修改其字节码生成子类来处理。什么是CGLIB动态代理使用cglib[Code Generation Library]实现动态代理并不要求委托类必须实现接口底层采用asm字节码生成框架生成代理类的字节码CGLIB动态代理相关代码public class CglibProxy implements MethodInterceptor { private Object targetObject; // 这里的目标类型为Object则可以接受任意一种参数作为被代理类实现了动态代理 public Object getInstance(Object target) { // 设置需要创建子类的类 this.targetObject target; Enhancer enhancer new Enhancer(); enhancer.setSuperclass(target.getClass()); enhancer.setCallback(this); return enhancer.create(); } public Object intercept(Object obj, Method method, Object[] args, MethodProxy proxy) throws Throwable { System.out.println(开启事物); Object result proxy.invoke(targetObject, args); System.out.println(关闭事物); // 返回代理对象 return result; } public static void main(String[] args) { CglibProxy cglibProxy new CglibProxy(); UserDao userDao (UserDao) cglibProxy.getInstance(new UserDao()); userDao.save(); }}CGLIB动态代理与JDK动态区别java动态代理是利用反射机制生成一个实现代理接口的匿名类在调用具体方法前调用InvokeHandler来处理。而cglib动态代理是利用asm开源包对代理对象类的class文件加载进来通过修改其字节码生成子类来处理。Spring中。1、如果目标对象实现了接口默认情况下会采用JDK的动态代理实现AOP2、如果目标对象实现了接口可以强制使用CGLIB实现AOP3、如果目标对象没有实现了接口必须采用CGLIB库spring会自动在JDK动态代理和CGLIB之间转换JDK动态代理只能对实现了接口的类生成代理而不能针对类 。 CGLIB是针对类实现代理主要是对指定的类生成一个子类覆盖其中的方法 。 因为是继承所以该类或方法最好不要声明成final final可以阻止继承和多态。AOP编程使用注解版本实现AOPAspect 指定一个类为切面类 Pointcut(execution(* com.service.UserService.add(..))) 指定切入点表达式Before(pointCut_()) 前置通知: 目标方法之前执行After(pointCut_()) 后置通知目标方法之后执行(始终执行)AfterReturning(pointCut_()) 返回后通知 执行方法结束前执行(异常不执行)AfterThrowing(pointCut_()) 异常通知: 出现异常时候执行Around(pointCut_()) 环绕通知 环绕目标方法执行ComponentAspectpublic class AopLog { // 前置通知 Before(execution(* com.service.UserService.add(..))) public void begin() { System.out.println(前置通知); } // 后置通知 After(execution(* com.service.UserService.add(..))) public void commit() { System.out.println(后置通知); } // 运行通知 AfterReturning(execution(* com.service.UserService.add(..))) public void returning() { System.out.println(运行通知); } // 异常通知 AfterThrowing(execution(* com.service.UserService.add(..))) public void afterThrowing() { System.out.println(异常通知); } // 环绕通知 Around(execution(* com.service.UserService.add(..))) public void around(ProceedingJoinPoint proceedingJoinPoint) throws Throwable { System.out.println(环绕通知开始); proceedingJoinPoint.proceed(); System.out.println(环绕通知结束); }}XML方式实现AOPXml实现aop编程1) 引入jar文件 【aop 相关jar 4个】 2) 引入aop名称空间 3)aop 配置 * 配置切面类 (重复执行代码形成的类) * aop配置 拦截哪些方法 / 拦截到方法后应用通知代码 public class AopLog2 { // 前置通知 public void begin() { System.out.println(前置通知); } // // 后置通知 public void commit() { System.out.println(后置通知); } // 运行通知 public void returning() { System.out.println(运行通知); } // 异常通知 public void afterThrowing() { System.out.println(异常通知); } // 环绕通知 public void around(ProceedingJoinPoint proceedingJoinPoint) throws Throwable { System.out.println(环绕通知开始); proceedingJoinPoint.proceed(); System.out.println(环绕通知结束); }}JAVA进阶架构程序员福利我这里还总结整理了比较全面的JAVA相关的面试资料都已经整理成了PDF版这些都可以分享给大家关注私信我【806】免费领取