44.2. 实施消息接口


如何实现自定义消息

例 44.2 “自定义消息实施” 概述如何通过扩展 DefaultMessage 类来实现消息。

例 44.2. 自定义消息实施

import org.apache.camel.Exchange;
import org.apache.camel.impl.DefaultMessage;

public class CustomMessage extends DefaultMessage { 
1


    public CustomMessage() { 
2

        // Create message with default properties...
    }

    @Override
    public String toString() { 
3

        // Return a stringified message...
    }

    @Override
    public CustomMessage newInstance() { 
4

        return new CustomMessage( ... );
    }

    @Override
    protected Object createBody() { 
5

        // Return message body (lazy creation).
    }

    @Override
    protected void populateInitialHeaders(Map<String, Object> map) { 
6

        // Initialize headers from underlying message (lazy creation).
    }

    @Override
    protected void populateInitialAttachments(Map<String, DataHandler> map) { 
7

        // Initialize attachments from underlying message (lazy creation).
    }
}
Copy to Clipboard Toggle word wrap
1
通过扩展 org.apache.camel.impl.DefaultMessage 类来实施自定义消息类 CustomMessage
2
通常,您需要一个默认的构造器,用于创建具有默认属性的消息。
3
覆盖 toString () 方法,以自定义消息字符串。
4
newInstance () 方法从 MessageSupport.copy () 方法内调用。newInstance () 方法 的自定义 应当侧重于将当前消息实例的所有自定义属性复制到新的消息实例中。MessageSupport.copy () 方法通过调用 copyFrom () 来复制通用消息属性。
5
createBody () 方法与 MessageSupport.getBody () 方法结合使用,以实施对消息正文的 lazy 访问权限。默认情况下,邮件正文为 null。只有在应用程序代码试图访问正文(通过调用 getBody ())访问应创建正文时,才会生效。当消息正文首次访问时,MessageSupport.getBody () 会自动调用 createBody ()
6
populateInitialHeaders () 方法可与标头 getter 和 setter 方法一起工作,以实施对消息标头的 lazy 访问。此方法解析消息以提取任何消息标头并将其插入到哈希 映射中,映射。当用户第一次试图访问标头(或标头)时,会自动调用 populateInitialHeaders () 方法(通过调用 getHeader (), getHeaders (), setHeader (), 或 setHeaders ())。
7
populateInitialAttachments () 方法与附件 getter 和 setter 方法协同工作,以实施对附件的 lazy 访问。此方法提取消息附加并将其插入到散列 映射 中。当用户第一次尝试通过调用 getAttachment ()、getAttachment ()、getAttachmentNames ()addAttachment () 时,会自动调用 populateInitial Attachments () 方法。
返回顶部
Red Hat logoGithubredditYoutubeTwitter

学习

尝试、购买和销售

社区

关于红帽文档

通过我们的产品和服务,以及可以信赖的内容,帮助红帽用户创新并实现他们的目标。 了解我们当前的更新.

让开源更具包容性

红帽致力于替换我们的代码、文档和 Web 属性中存在问题的语言。欲了解更多详情,请参阅红帽博客.

關於紅帽

我们提供强化的解决方案,使企业能够更轻松地跨平台和环境(从核心数据中心到网络边缘)工作。

Theme

© 2025 Red Hat