当前位置: 首页 > news >正文

spring切面

概念

两个特点:

  • IOC控制反转
  • AOP主要用来处理公共的代码

例如一个案例就是添加用户,重复的代码包含了记录日志、事务提交和事务回滚等,都是重复的,为了简单,交给AOP来做。

  • 即将复杂的需求分解出不同方面,将散布在系统中的公共功能集中解决。(例如有关security,persistence,logging等不同方面的代码,)
  • 采用代理机制组装起来运行,在不改变原程序的基础上对代码段进行增强处理,增加新的功能。

回到添加用户的案例,把不同面的代码单独抽出去,当程序运行到方法时,例如方法前,可以动态将该面的程序动态的切进去,方法运行完也可以动态的切进去。

通过代理对象调用原来对象的方法。代理对象方法前后都可插入代码,这些代码就是增强处理。动态代理的经典实现。

所谓面向切面编程,即一种通过预编译和运行期动态代理的方式,实现在不修改源代码的情况下给程序动态添加功能的技术。

相关术语

增强处理:

  • 前置增强
  • 后置增强
  • 环绕增强、异常抛出增强、最终增强等类型

切入点Pointcut : 往哪里切

连接点 Join Point:切的地方会产生连接点,根据连接点获得一些参数

切面 Aspect:

目标对象 Target object:切的是谁

AOP代理:指代增强

织入 Weaving:动态切入

案例

例如下面的,插入AOP

public class UserServiceImpl implements UserServie{private UserDao userDao;@Overridepublic void show() {userDao.show();}}

想在show方法之前打印日志,show方法之后也打印日志。不建议System.out.println()。在打印日志的时候,用到log,输出打印的信息并会带上确定的时间,方便排查错误。

import org.apache.log4j.Logger;public class Log {private Logger logger = Logger.getLogger(Log.class);public static void main(String[] args){logger.info("打印日志, info");logger.debug("打印日志, debug");logger.warn("打印日志, warn");logger.error("打印日志, error");}}

如何在show方法执行结束后运行呢?
添加切点。
<aop:pointcut expression="execution( * com.kgc.service.. * . * (..))" id="point"/>
然后进行增强处理。

又例如权限拦截器中的示例:

使用Spring AOP实现权限拦截器,用于在方法执行前或执行过程中进行权限校验,例如角色检查。

    @Around("@annotation(authCheck)")public Object doInterceptor(ProceedingJoinPoint joinPoint, AuthCheck authCheck) throws Throwable {// 获取注解中的权限要求String mustRole = authCheck.mustRole();// 怎么拿到当前用户的登陆信息呢?RequestAttributes requestAttributes = RequestContextHolder.currentRequestAttributes();// 转换为servletHttpServletRequest request = ((ServletRequestAttributes) requestAttributes).getRequest();User loginUser = userService.getLoginUser(request);// 获取用户的权限类型UserRoleEnum mustRoleEnum = UserRoleEnum.getEnumByValue(mustRole);// 如果权限要求为空,则继续执行原来的方法if (mustRoleEnum == null){return joinPoint.proceed();}// 反之,以下的代码就是必须有权限才会通过// 也要将获取到当前用户的角色转换成枚举类,方便使用UserRoleEnum userRoleEnum = UserRoleEnum.getEnumByValue(loginUser.getUserRole());// 如果为空则异常if (userRoleEnum == null){throw new BusinessException(ErrorCode.NOT_AUTH_ERROR);}// 要对必须有管理员权限,即mustRoleEnum为ADMIN,但是用户的权限不是管理员权限,则异常if (UserRoleEnum.ADMIN.equals(mustRoleEnum) && !UserRoleEnum.ADMIN.equals(userRoleEnum)){throw new BusinessException(ErrorCode.NOT_AUTH_ERROR);}// 其他情况就是通过权限校验的return joinPoint.proceed();}

参考

AOP切面的实现

http://www.xdnf.cn/news/732547.html

相关文章:

  • 栈与队列:数据结构的有序律动
  • JS入门——三种输入方式
  • docker不用dockerfile
  • GSR 手环能耗数据实测:STM32 与 SD NAND 的功耗优化成果
  • 信息安全管理与评估2025山东卷
  • ONLYOFFICE深度解锁系列.4-OnlyOffice客户端原理-真的不支持多端同步
  • 使用 Kafka + Protobuf 实现高效的序列化通信
  • 【合集】Linux——31个普通信号
  • Eclipse集成lombok
  • 电子电路:VCC电源是什么?
  • 从图像处理到深度学习:直播美颜SDK的人脸美型算法详解
  • 初学c语言21(文件操作)
  • 小程序32-简易双向数据绑定
  • 千库/六图素材下载工具
  • redis内存数据库
  • 每处理器变量和每处理器计数器
  • 「Java教案」Java程序的构成
  • SAP Business One:无锡哲讯科技助力中小企业数字化转型的智慧之选
  • ImBatch 7.6.3 中文版 - 高效图片批量处理工具
  • 放假带出门的充电宝买哪种好用耐用?倍思超能充35W了解一下!
  • Vue Element tree lable组合展示
  • 2014药柜设计问题
  • 【Linux】深入解析:云服务器连接 XShell、Linux 目录结构和常用命令
  • Python中的异常处理:如何优雅地处理程序中的错误
  • 面试-【搜索引擎】
  • 历年厦门大学计算机保研上机真题
  • 基于原生JavaScript前端和 Flask 后端的Todo 应用
  • 西门子PLC的维修
  • 【C】位运算
  • 安全帽目标检测