码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • Spring进阶(AOP的应用)—— 动态代理AOP后controller层的private方法访问失效的问题


    在这里插入图片描述

    前言

    动态代理,面向切面编程AOP(Aspect Oriented Programming)作为spring中的一个重点和难点,需要不断深入理解,并且在项目中学习如何灵活应用。

    本篇博客介绍动态代理AOP在实际应用中遇到的private方法访问失效的问题。

    其他相关的增强方法AOP的文章列表如下:

    Spring基础(核心容器)——从配置文件到注解开发 & 创建对象+成员变量赋值IOC & 增强方法AOP

    在这里插入图片描述
    Spring进阶(AOP的理解)——静态/动态代理 & 面向切面编程AOP(Aspect Oriented Programming) & 日志记录 & 增强方法

    在这里插入图片描述

    目录

    • 前言
    • 引出
    • 1.用增强方法AOP给controller层增强
    • 2.调用controller的api时发现依赖注入为null
    • 3.采用debug模式启动查看
    • 4.原因:controller层方法为private
    • 5.解决:修改成public
    • 总结

    引出


    动态代理AOP后controller层的private方法访问失效的问题的发现和解决

    1.用增强方法AOP给controller层增强

    在这里插入图片描述

    package com.tianju.fresh.aop;
    
    import com.woniu.fresh.util.JwtUtil;
    import lombok.extern.slf4j.Slf4j;
    import org.aspectj.lang.JoinPoint;
    import org.aspectj.lang.annotation.Aspect;
    import org.aspectj.lang.annotation.Before;
    import org.springframework.beans.factory.annotation.Autowired;
    import org.springframework.stereotype.Component;
    import org.springframework.web.context.request.RequestContextHolder;
    import org.springframework.web.context.request.ServletRequestAttributes;
    
    import javax.servlet.http.HttpServletRequest;
    import javax.servlet.http.HttpServletResponse;
    import java.text.SimpleDateFormat;
    import java.util.Arrays;
    import java.util.Date;
    import java.util.Map;
    
    /**
     * 进行日志的记录
     */
    @Component
    @Aspect
    @Slf4j // 用lombok.extern.slf4j.Slf4j;
    public class LoggingAsp {
    
        // 给所有标注了@Controller注解的方法做增强
        @Before("@within(org.springframework.web.bind.annotation.RestController)")
    
        public void log(JoinPoint joinPoint){
            String className = joinPoint.getTarget().getClass().getSimpleName(); // 获取类名
            String methodName = joinPoint.getSignature().getName(); // 获取方法名
            Object[] args = joinPoint.getArgs(); // 获取传的参数
    
            // 获取一下httpRequest
            ServletRequestAttributes attributes = (ServletRequestAttributes) RequestContextHolder.getRequestAttributes();
            HttpServletRequest request = attributes.getRequest();
    
            String username;
            try {
                // 获得用户名
                String jwt = request.getHeader("jwt");
                Map userInfo = JwtUtil.getUserInfo(jwt);
                log.debug("登陆的用户的信息:"+userInfo);
                username = userInfo.get("username")+"-"+userInfo.get("realName");
            } catch (Exception e) {
                username = "神秘的用户";
            }
    
            SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss.SSS");
            Date date = new Date();
            String formattedDate = sdf.format(date);
    
            // ip地址
            String ipAddress = request.getRemoteAddr();
            log.info(">>>> LOG {} 从ip地址 {} {}访问了 {} 类的 {} 方法,传的参数为 {} ",
                    formattedDate, ipAddress, username,className,methodName, Arrays.toString(args));
        }
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31
    • 32
    • 33
    • 34
    • 35
    • 36
    • 37
    • 38
    • 39
    • 40
    • 41
    • 42
    • 43
    • 44
    • 45
    • 46
    • 47
    • 48
    • 49
    • 50
    • 51
    • 52
    • 53
    • 54
    • 55
    • 56
    • 57
    • 58
    • 59
    • 60

    2.调用controller的api时发现依赖注入为null

    在打开增强方法AOP之后,报错信息显示的是空指针异常,这就比较奇怪了,因为@autowired没有爆红,说明IOC容器中有这个类,但是这里竟然说它是一个null。

    在这里插入图片描述

    3.采用debug模式启动查看

    采用debug模式查看,访问该api接口,发现确实这两个依赖注入的实体类为null,所以就报错,空指针异常

    在这里插入图片描述

    4.原因:controller层方法为private

    经过检查发现,controller层的方法是private,原来是这样的问题

    在这里插入图片描述

    5.解决:修改成public

    修改成public,这两个就不为null了

    在这里插入图片描述

    总结

    动态代理AOP后controller层的private方法访问失效的问题的发现和解决

    在这里插入图片描述

  • 相关阅读:
    字符串的认识
    JDK中的Set和Map解析
    华为OD机考算法题:食堂供餐
    HTML学生个人网站作业设计:我的家乡网站设计——南宁留言表单 无js 页面8个
    Spark底层原理:案例解析(第34天)
    oracle 查询2021年至今仅在B2C渠道购物过的用户数
    Linux常用命令分享之收藏必备
    【探索Linux】P.39(传输层 —— TCP的三次 “握手” 和四次 “挥手” )
    独立站引流技巧和营销思路
    MySQL之SQL语句优化
  • 原文地址:https://blog.csdn.net/Pireley/article/details/133341988
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号