springboot 2.3.2演示环境搭建(preview环境、DEMO环境)防止演示用户恶意进行删除操作

本文介绍了如何在SpringBoot 2.3.2的演示环境中,通过AOP和全局异常处理防止用户恶意删除管理员账号,避免系统登录问题。详细步骤包括编写AOP切面和异常处理代码。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

使用背景

自从搭建matecloud的演示环境后,经常有人无故删除管理员账号信息,导致一段时间后,系统出现无法登录的情况。

实现步骤

通过AOP的方式实现,步骤如下:

写AOP

写PreviewAspect,主要拦截返回值为Result的方法。

package vip.mate.system.aspect;

import lombok.extern.slf4j.Slf4j;
import org.apache.commons.lang3.StringUtils;
import org.aspectj.lang.ProceedingJoinPoint;
import org.aspectj.lang.annotation.Around;
import org.aspectj.lang.annotation.Aspect;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.http.HttpMethod;
import org.springframework.stereotype.Component;
import vip.mate.core.common.exception.PreviewException;
import vip.mate.core.common.util.RequestHolder;

import javax.servlet.http.HttpServletRequest;

/**
 * 演示环境拦截器
 * @author pangu
 */
@Slf4j
@Aspect
@Component
public class PreviewAspect {
   

    @Value("${mate.isPreview}")
    private boolean isPreview = false;

    @Around(
            "execution(static vip.mate.core.common.api.Result *(..)) || " +
                    "(@within(org.springframework.stereotype.Controller) || " +
                    "@within(org.springframework.web.bind.annotation.RestController))"
    )
    public Object aroundApi(ProceedingJoinPoint point) throws Throwable {
   
        // 获取request
        HttpServletRequest request = RequestHolder.getHttpServletRequest()
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值