[SpringBoot] 8. aop 获取 request response

最近开发有一个需求需要在 aop 中获取request response ,搜索许久没有答案,故此记录📝~


aop 获取

java 复制代码
package com.example.easy_im.aop;

import com.example.easy_im.Context;
import jakarta.servlet.http.HttpServletRequest;
import jakarta.servlet.http.HttpServletResponse;
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.stereotype.Component;
import org.springframework.web.context.request.RequestContextHolder;
import org.springframework.web.context.request.ServletRequestAttributes;

import java.util.Objects;

@Aspect
@Component
@Slf4j
public class TokenAop {


    @Around("@annotation(com.example.easy_im.annotation.NeedToken)")
    public Object check(ProceedingJoinPoint pjp) throws Throwable {

        try {
            HttpServletRequest servletRequest = ((ServletRequestAttributes) Objects.requireNonNull(RequestContextHolder.getRequestAttributes())).getRequest();
            HttpServletResponse servletResponse = ((ServletRequestAttributes) RequestContextHolder.getRequestAttributes()).getResponse();
            String authorizationHeader = servletRequest.getHeader("Authorization");
            if(StringUtils.isBlank(authorizationHeader) || servletResponse == null) {
                servletResponse.setStatus(HttpServletResponse.SC_UNAUTHORIZED);
                return "请携带Authorization请求头";
            }

            // 执行目标方法
            Object proceed = pjp.proceed();

            Context.clear();

            return proceed;
        } catch (Exception e) {
            return "fail";
        }

    }
}

其他部分代码

java 复制代码
package com.example.easy_im.annotation;

import java.lang.annotation.ElementType;
import java.lang.annotation.Retention;
import java.lang.annotation.RetentionPolicy;
import java.lang.annotation.Target;

@Retention(RetentionPolicy.RUNTIME)
@Target(ElementType.METHOD)
public @interface NeedToken {
}
java 复制代码
package com.example.easy_im.controller;

import com.example.easy_im.Context;
import com.example.easy_im.annotation.NeedToken;
import com.example.easy_im.dao.UserDao;
import com.example.easy_im.entity.User;
import com.example.easy_im.util.TokenUtil;
import jakarta.annotation.Resource;
import org.springframework.data.domain.Example;
import org.springframework.validation.annotation.Validated;
import org.springframework.web.bind.annotation.*;

import java.util.Optional;

@RestController
@RequestMapping("/user")
public class UserController {

    @Resource
    private UserDao userDao;

    @PostMapping("/login")
    public String login(@Validated @RequestBody User user) {
        User obj = userDao.findUserByNameAndPwd(user.getUserName(), user.getUserPwd());

        if(obj == null) {
            return "fail";
        }
        return TokenUtil.generateToken(obj);
    }

    @DeleteMapping("/logout")
    @NeedToken
    public String logout() {
        String token = Context.getToken();
        TokenUtil.destroyToken(token);
        return "ok";
    }



}
相关推荐
中国胖子风清扬2 分钟前
Rust 序列化技术全解析:从基础到实战
开发语言·c++·spring boot·vscode·后端·中间件·rust
bobz96525 分钟前
分析 docker.service 和 docker.socket 这两个服务各自的作用
后端
野犬寒鸦37 分钟前
力扣hot100:旋转图像(48)(详细图解以及核心思路剖析)
java·数据结构·后端·算法·leetcode
七夜zippoe1 小时前
AI+Java 守护你的钱袋子!金融领域的智能风控与极速交易
java·人工智能·金融
岁忧1 小时前
(LeetCode 面试经典 150 题) 200. 岛屿数量(深度优先搜索dfs || 广度优先搜索bfs)
java·c++·leetcode·面试·go·深度优先
phiilo1 小时前
golang 设置进程退出时kill所有子进程
后端
花花无缺1 小时前
python自动化-pytest-用例发现规则和要求
后端·python
程序员小假1 小时前
我们来说一说 Cglib 与 JDK 动态代理
后端
liliangcsdn2 小时前
结合prompt分析NodeRAG的build过程
java·服务器·人工智能·数据分析·知识图谱
黑色的山岗在沉睡2 小时前
LeetCode 189. 轮转数组
java·算法·leetcode