SWIFT ACK 消息解析

Posted

技术标签:

【中文标题】SWIFT ACK 消息解析【英文标题】:SWIFT ACK Message Parsing 【发布时间】:2016-04-21 00:14:17 【问题描述】:

我正在通过基于 java 的应用程序生成 SWIFT 消息 MT 110 和 MT 103。为了与最终客户进行对账和共享,我们需要将从 SWIFT 终端收到的 Ack Nak 消息映射回 MT 110 和 MT 103 交易。为此,我需要解析每个 ACK​​ 文件并找出

20:发件人参考 ABC1380Q02418

451:0 (ACK)

451:1 (NAK) 然后是 405 字段。

我曾尝试使用 Prowide Core (WIFE) 开源 SWIFT Java 库执行此操作,但我无法解析 ACK。通过库,我能够解析 MT 110 和 MT 103 消息,但不能解析 ACK 或 NAK 消息。需要您帮助了解如何通过 Prowide Core (WIFE) 开源 SWIFT Java 库解析 SWIFT ACK NAK 文件。

下面粘贴的示例 ACK 消息:

23/12/15-11:50:14 BulBoardCTFACK-0192-000001 1


---------- 实例类型和传输 --------------

发送至 SWIFT (ACK) 的原始通知(传输)

网络传送状态:网络确认

优先级/交付:正常

消息输入参考:1150 151223ABCINBBADEL2567311531

--------------- 消息头 ------------------ -------

Swift 输入:FIN 103 单一客户信用转移

发件人:ABCDINBBDEL TTTT银行有限公司 (XXXX分行) YYYYYYYY YY

接收器:ANZBAU3MXXX 澳新银行集团有限公司 墨尔本澳大利亚

--------------- 消息文本 ------------------ ---------

20:发件人参考 ABC1380Q02418

23B:银行操作代码 信用

32A:Val Dte/Curr/Interbnk Settld Amt 日期:2015 年 12 月 23 日 货币:AUD(澳元) 金额:#8000,0#

33B:货币/指示金额 货币:AUD(澳元) 金额:#8000,0#

50K:订购客户名称和地址 /M4132378 ABC DEF GHI 76 AX , 模型镇 EXT , XXXXXXX

53A:发件人的通讯员 - FI BIC /1111111 00001 ABCDEFBBDEL ABC

57D:具有 Inst -Name & Addr 的帐户 //AU063144 共同财富银行 澳大利亚 SWIFT 代码 CTBAAU2S

59:受益人客户名称和地址 /555555 ABCDEF YYYYYYYY

70:汇款信息 维护

71A:收费详情 本

71F:寄件人的费用 货币:AUD(澳元) 金额:#0,0#

--------------- 消息尾 ------ ------

CHK:41B1AA23FEDF

PKI 签名:MAC 等效

---------------------------- 干预 ------ -------

类别:网络报告

创作时间:23/12/15 11:50:03

应用:SWIFT 接口

操作员:系统

文字

1:F21ABCDEFBBADEL25673115314:177:1512231150451:0

【问题讨论】:

嗨,你有没有找到任何 ACK/NACK 消息的解析器我发现的唯一有用的东西是 sepaforcorporates.com/swift-for-corporates/… 不,我没有找到任何库,我们已经开发了自己的代码。 我们也是。我已在 WIFE - Prowide Core sourceforge.net/p/wife/support-requests/18 上发布请求 【参考方案1】:

发布的示例是扩展打印输出,而不是 SWIFT FIN 格式的消息。但是,在最后一行称为“文本”的地方有 FIN 系统消息,可以由 Prowide Core 解析。

1:F21ABCDEFBBADEL25673115314:177:1512231150451:0

系统消息中的字段 451 指示消息是被确认 (0) 还是被确认 (1)。当 nacked 字段 405 将包含错误代码。例如:405:T33002

最常见的结构是带有 ACK/NAK 的系统消息,后跟原始消息的完整副本:

1:F21LITEBEBBAXXX00660000794:177:1104180901451:01:F01LITEBEBBAXXX00660000792:I999LITEBEBBXXXXN4:
:20:TESTREF1
:79:This is text line 1
-5:CHK:7602B010CF31TNG:

第一步是确定接收到的消息是否为 ACK/NAK。一旦消息被解析为 SwiftMessage,这个方法可以用来验证它是一个普通的 FIN 用户到用户的消息,还是一个带有 ACK/NAK 的系统消息

SwiftMessage.isSystemMessage()
SwiftMessage.isAck()
SwiftMessage.isNack()

第二步是将 ACK/NAK 信息从原始消息的标识中分离出来。此示例使用最常见的格式,即 ACK/NAK 消息后跟原始消息的完整副本(例如,SAA AFT 或 SA Lite 自动客户端使用的格式)。解析 ACK/NAK 和原始副本:

Swiftparser parser = new SwiftParser();
SwiftMessage ack = parser.parse(msg);
SwiftMessage original = parser.parse(ack.getUnparsedTexts().getAsFINString());

最后,要将 acked/nacked 消息与其原始消息匹配,必须对候选者进行查询(通常搜索同一天和相同消息类型的消息)。查找候选者不在库中,因为它涉及搜索应用程序数据库或从文件系统目录读取发送的消息。虽然,在候选人中,匹配可以这样完成:

AckMessageComparator comparator = new AckMessageComparator();
    for (SwiftMessage candidate : candidates) 
        if (comparator.compare(original, candidate) == 0) 
            //candidate is the message acked/nacked
        
    

根据确认通知源的不同,消息的结构可能会有所不同。例如,原始消息的完整副本可能会丢失。但是,必须存在对原始 acked/nacked 消息的其他类型的引用,例如 MUR(消息用户参考),如下所示:

1:F21LITEBEBBAXXX00660000794:177:1104180901451:0108:FOO16101900001

所以要匹配原始消息,而不是使用完整的消息副本和 AckMessageComparator,必须找到具有相同 MUR 的消息:

for (SwiftMessage candidate : candidates) 
        if (StringUtils.equals(ack.getMUR(), candidate.getMUR())) 
             candidate is the message acked/nacked
        
    

如果 ACK/NAK 中既不存在原始消息副本也不存在 MUR,则可能存在 UUID(唯一标识符),并且可以从 UUID 字段(如接收方地址、消息类型和引用)中匹配候选者。

ACK/NAK 必须以某种方式提供信息以正确匹配被确认的原始消息。

【讨论】:

【参考方案2】:

ACK/NAK 通知使用服务 ID 21 进行标识。

您可以使用 Prowide Core 中的 ServiceMessage21 类来解析 Acks 和 Nacks

https://www.javadoc.io/doc/com.prowidesoftware/pw-swift-core/SRU2018-7.10.4

【讨论】:

以上是关于SWIFT ACK 消息解析的主要内容,如果未能解决你的问题,请参考以下文章

RocketMQ:消息ACK机制源码解析

.NET 的 SWIFT 消息解析 [关闭]

使用 WIFE Java 库的 SWIFT MT 消息解析

在 Powershell 中使用 REGEX 解析 SWIFT(财务)消息字符串

Kafka源码深度解析-系列1 -消息队列的策略与语义

如何正确解析 SWIFT 中的 JSON 对象