通过AOP 实现权限登录拦截 springboot+mybatis-plus

文章介绍了如何在SpringBoot项目中结合MyBatis-Plus,利用AOP(面向切面编程)实现权限登录拦截。主要涉及两种实现方式:自定义注解和切点(@Pointcut)。作者选择了切点方式,通过定义切面类和切点来拦截所有Controller层的方法,实现了在方法执行前进行权限验证的功能。
摘要由CSDN通过智能技术生成

通过AOP 实现权限登录拦截 springboot+mybatis-plus

需求:公司为了实现拦截未登录的用户直接请求接口,要求Java与前端都要做出安全拦截
设计:想通过spring的AOP方式实现,于是去网上查看了相关资料
参考:可参考博客

第一步:公司项目没有用过AOP需要引入相关的依赖

   <dependency>
       <groupId>org.springframework.boot</groupId>
       <artifactId>spring-boot-starter-aop</artifactId>
   </dependency>

实现方式有两种,一种是通过自定义注解的方式,一种是通过@Pointcut切点的方式实现,对我来说Java对外的接口基本都要拦截,注解的方式并不适合我,于是选择了切点的方式拦截自定义的controller类即可,下面两种都可以简单的记录下,以供参考

通过@Pointcut切点的方式实现

创建一个切面类PermissionAspect并引入相关注解

在这里插入图片描述

@Aspect //表示这是一个切面
@Component //交给springboot管理
//@ResponseBody
public class PermissionAspect {}

定义一个切点,表示需要对哪些类生效,我这里暂时是想拦截所有的控制层的代码,加上对用的不是很熟练下这样将就着用吧
在这里插入图片描述

	/**
     * 定义切点,这是一个标记方法
     */
    @Pointcut("execution(* com.danganku.file.controller.*Controller.*(..))")
    //@Pointcut("execution(  * com.danganku.file.controller.UpdateController.*(..)))")
    public void pointCunt(){}

定义一个前置方法的注解,我是想在程序执行前就执行我的拦截方法
你可以根据需求选择前置方法后置方法或者环绕哦
AspectJ支持的5种类型的通知注解:
@Before:前置通知,在方法执行之前执行

@After:后置通知,在方法执行之后执行

@AfterRunning:返回通知,在方法返回结果后执行

@AfterThrowing:异常通知,在方法抛出异常之后执行

@Around:环绕通知,围绕着方法执行
在这里插入图片描述

	@Before("pointCunt()" )//pointCunt():上面代码的定义的方法,可以自己定义
    public void Before(JoinPoint joinPoint){
        //try {
//            logger.info("---前置通知---");
//
//            // 获取目标方法的参数信息
//            logger.info("目标对象参数信息: {}", Arrays.toString(joinPoint.getArgs()));
//
//            // AOP代理类的信息
//            logger.info("AOP代理类: {}", joinPoint.getThis());
//
//            // 代理的目标对象
//            logger.info("代理的目标对象: {}", joinPoint.getTarget());
//
//            // 通知的签名
//            Signature signature = joinPoint.getSignature();
//            // 代理的是哪一个方法
//            logger.info("代理的方法名: {}", signature.getName());
//
//            // AOP代理类的名字
//            logger.info("AOP代理类的名字: {}", signature.getDeclaringTypeName());
//
//            // AOP代理类的类信息
//            logger.info("AOP代理类的类信息: {}", signature.getDeclaringType());

		/**
		*你的逻辑代码
		*/
        System.out.println("通过权限验证");

    }

到此切点方式基本就结束了,博主也是第一次用,记录一下,加深印象,有问题也可以联系我

下面看下使用的注解的方式

第一步:定义一个注解类Permission
在这里插入图片描述

@Target({ElementType.TYPE,ElementType.METHOD} )
@Retention(RetentionPolicy.RUNTIME)
@Documented
public @interface Permission {
}

@Target:
1.CONSTRUCTOR:用于描述构造器
   2.FIELD:用于描述域
    3.LOCAL_VARIABLE:用于描述局部变量
    4.METHOD:用于描述方法
    5.PACKAGE:用于描述
    6.PARAMETER:用于描述参数
    7.TYPE:用于描述类、接口(包括注解类型) 或enum声明
@Retention(注解的生命周期):
1、RetentionPolicy.SOURCE:注解只保留在源文件,当Java文件编译成class文件的时候,注解被遗弃;
2、RetentionPolicy.CLASS:注解被保留到class文件,但jvm加载class文件时候被遗弃,这是默认的生命周期;
3、RetentionPolicy.RUNTIME:注解不仅被保存到class文件中,jvm加载class文件之后,仍然存在;
@Documented:用于描述其他类型的annotation应该作为标记的程序成员的公共应用编程接口
如果要注解生效的话可以看下图,类的标识符号是变了的哦,会有一个绿色的@符号
在这里插入图片描述
第二步:定义一个前置方法,然后实现我们的业务代码
在这里插入图片描述

@Before( value = "@annotation(permission)")
    public Result userPermission(  JoinPoint  joinpoint,Permission permission) throws Exception {
        System.out.println("权限验证");

        //1.获取请求参数
        Object[] objects = joinpoint.getArgs();
        for(Object obj : objects){
            if (obj instanceof Sessions){
                String sessionById = sessionService.findSessionById(((Sessions) obj).getPHPSESSID().toString());
                //若校验失败,抛出自定义异常
                if (StringUtils.isBlank(sessionById)){
                    System.out.println( "抱歉,您无该操作权限" );
                    throw new CustomException(ExceptionEnum.USER_PERMISSION);
                }
            }
        }
        return ResultUtil.ResultSuccess("","");

    }

最后一步,再对应的方法引入注解
在这里插入图片描述

注解方式也到此结束了,博主也是第一次使用了,测试过没有问题,可以参考下哦

  • 11
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
抱歉,我是一名语言模型AI,无法为您提供具体的代码实现。但是我可以提供一些思路和步骤。 1. 准备好环境 首先需要安装Java、IntelliJ IDEA、MySQL等软件,并创建好相应的数据库和表。需要添加相关的依赖,比如spring-boot-starter、mybatis-plus-boot-starter等等,以及Ajax和LayUI的相关库。 2. 创建实体类和Mapper接口 创建员工和日志的实体类,以及对应的Mapper接口,用于对数据库进行操作。可以使用Mybatis-Plus的代码生成器来自动生成基础的代码。 3. 编写业务逻辑层 在业务逻辑层中编写增删改查等操作方法,以及一些自定义的业务方法,用于处理员工和日志的具体业务需求。 4. 编写Controller层 在Controller层中处理请求和返回数据,并调用相应的业务逻辑方法。可以使用Ajax来实现异步提交数据和返回结果,使用LayUI框架来美化页面和处理交互逻辑。 5. 添加安全认证和日志记录 添加安全认证功能,以实现员工的登录、登出等操作,并记录相关的日志信息。可以使用Spring Security等框架来实现认证和授权,并使用AOP技术来记录日志信息。 6. 测试和部署 在本地进行测试,并将代码打包部署到服务器上。可以使用Maven来管理依赖和构建项目,使用Docker等容器技术来部署和管理应用程序。 以上就是实现员工管理和日志管理的大致步骤和思路。当然,具体实现还需要根据具体的业务需求和技术选型来进行调整和优化。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值