当前位置: 首页 > 知识库问答 >
问题:

Spring AOP不起作用

谢涵亮
2023-03-14

我使用Spring AOP来实现我的应用程序的日志系统。但我有一些麻烦。

我有简单的课

@Component
@Scope(BeanDefinition.SCOPE_PROTOTYPE)
public class MessageReceiverImpl implements MessageReceiver {
    final private BufferedReader reader;

    public MessageReceiverImpl(BufferedReader reader) {
        this.reader = reader;
    }
    public String receive(){
        String msg = null;
        try {
            msg = reader.readLine();
        } catch (IOException e) {
            e.printStackTrace();
        }
        return msg;
    }
}
@Aspect
public class LoggerMessage {

    private static final Logger log = Logger.getLogger("listenerLogger");

    @Before("execution(* server.logic.listener.message.MessageReceiverImpl.receive(..))")
    public void logMessageReceiver() {
        log.info("INFO : LoggerMessage -> new Client");
    }
}
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
       xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"     xmlns:aop="http://www.springframework.org/schema/aop"
       xsi:schemaLocation="http://www.springframework.org/schema/beans
    http://www.springframework.org/schema/beans/spring-beans-3.0.xsd
    http://www.springframework.org/schema/aop
    http://www.springframework.org/schema/aop/spring-aop-3.0.xsd ">

    <aop:aspectj-autoproxy>
        <aop:include name="loggerMessage"/>
    </aop:aspectj-autoproxy>
    <aop:aspectj-autoproxy proxy-target-class="true"/>

    <!-- Aspect -->
    <bean id="loggerMessage" class="service.logger.listener.LoggerMessage" />

</beans>
@Bean
@Scope(BeanDefinition.SCOPE_PROTOTYPE)
 UploadSession getSession(Socket socket) {
    UploadSessionImpl uploadSession = null;
    try {
        uploadSession = new UploadSessionImpl(socket);

        BufferedReader reader = new BufferedReader(new InputStreamReader(socket.getInputStream()));
        MessageReceiver receiver = new MessageReceiverImpl(reader);
        uploadSession.setReceiver(receiver);

        PrintWriter out = new PrintWriter(socket.getOutputStream(), true);
        MessageSender sender = new MessageSenderImpl(out);
        uploadSession.setSender(sender);

        uploadSession.setBaseDir(context.getEnvironment().getProperty("listener.test-runs-folder"));
    } catch (IOException e) {
        e.printStackTrace();
    }
    return uploadSession;
}
public class UploadSessionImpl implements UploadSession,     ApplicationContextAware {

private MessageReceiver receiver;

public UploadSessionImpl(Socket socket) throws IOException {
    this.socket = socket;
}

public void process() throws IOException {
    String msg;

    while (true) {
        msg = receiver.receive();
        if (msg.equals("close")) break;
        ...
    }
}

共有1个答案

周涵畅
2023-03-14

到目前为止,从您的代码来看,您似乎在搞乱bean创建配置。尝试以下内容:

    @Bean
    @Scope(BeanDefinition.SCOPE_PROTOTYPE)
    public BufferedReader bufferedReader(Socket socket) throws Exception {
        return new BufferedReader(new InputStreamReader(socket.getInputStream()));
    }

    @Bean
    @Scope(BeanDefinition.SCOPE_PROTOTYPE)
    public MessageReceiver receiver(BufferedReader bufferedReader) {
        return new MessageReceiverImpl(bufferedReader);
    }

    @Bean
    @Scope(BeanDefinition.SCOPE_PROTOTYPE)
    UploadSession getSession(Socket socket, MessageReceiver receiver) {
        UploadSessionImpl uploadSession = null;
        try {
            uploadSession = new UploadSessionImpl(socket);

            BufferedReader reader = new BufferedReader(new InputStreamReader(socket.getInputStream()));
            uploadSession.setReceiver(receiver);

            PrintWriter out = new PrintWriter(socket.getOutputStream(), true);
            MessageSender sender = new MessageSenderImpl(out);
            uploadSession.setSender(sender);

            uploadSession.setBaseDir(context.getEnvironment().getProperty("listener.test-runs-folder"));
        } catch (IOException e) {
            e.printStackTrace();
        }
        return uploadSession;
    }
 类似资料:
  • 嗨,我有一个使用Spring 5、Spring Data、Spring AOP和Java 11的应用程序(我也在使用JAVA 9模块系统)。我的spring-context/spring-aspects版本是5.1.2.RELEASE Spring数据版本是2.1.2.RELEASE这两个版本都是最新的。我以下列方式创建了存储库: 我已启用Spring Data Repositories使用 在我

  • 主要内容:读者,前提条件,Spring AOP 概述Spring框架的关键组件之一是面向方面编程(AOP)框架。 面向方面的编程需要将程序逻辑分解成不同的部分。 此教程将通过简单实用的方法来学习Spring框架提供的AOP/面向方面编程。 读者 本教程主要是为Spring 面向方面编程(AOP)初学者准备的,帮助他们了解与Spring的AOP框架相关的基础到高级概念。 前提条件 在开始练习本教程系列文章中给出的各种类型的示例之前,我们假设您已经了解

  • 因此,我在一个控制器中有一个非常简单的代码片段,在这个代码片段中,我使用从外部文件中获取数据,它工作得很好!但是当我使用时,我会在控制台中得到一个

  • 问题内容: 正则表达式似乎还可以,因为第一行将子字符串正确替换为“ helloworld”,但是后者却不匹配,因为我看不到“ whynothelloworld?”。在控制台上 问题答案: 期望 整个 字符串匹配,而不仅仅是子字符串。 使用正则表达式匹配器对象的方法代替:

  • 问题内容: 我的 活动无法正常进行。 以下是我一一尝试过的代码段,但无济于事: 使用方法实施 设定方法 使用方法 这是我完整的MainActivity.java文件: 问题答案: 我遇到了同样的问题,我发现Android非常注重布局XML。我将NavigationView作为DrawerLayout的第一个孩子,但是出于某些愚蠢的原因,它必须是最后一个孩子。因此,您的布局必须具有以下顺序的元素:

  • 问题内容: 在什么情况下,java的System.out.println无法产生任何输出。我在方法内部调用了它,有时在调用该方法时得到了println,而有时却没有。 更新:我还在println之后使用System.out.flush()。 更新:感谢您的调试帮助。原来,阻止调用打开了一个对话框,使输出看起来与正常顺序大相径庭。我以为我要打印消息的方法是在对话框关闭时被调用的,但是该方法本身就是在

  • 问题内容: 第一次运行此sql时,需要39秒,再次运行并增加SQL_NO_CACHE时,它似乎没有生效: 我在这里尝试了多种方法 甚至重新启动mysql服务器或更改表名,但我仍然不能让39秒运行此SQL 我替换了另一个SQL,并在第一次运行SQL_NO_CACHE上增加了一个,问题是一样的: 是什么原因?如何获得相同的SQL运行时? 我想找到一种方法来优化此SQL以执行39秒 顺便说一句: 不起作

  • 问题内容: 我正在尝试使用此API用Java开发TS3 Bot:https : //github.com/TheHolyWaffle/TeamSpeak-3-Java- API 我有一个客户端所有服务器组的列表: 现在,我检查列表是否包含组: 结果是错误的。我100%确定此列表包含ServerGroup。 已经使用Sysouts进行了检查。 这是ServerGroup类的链接:[https]( h