java - 解析 iso8583 消息时出现问题

标签 java android bitmap iso8583

我从这里下载代码https://github.com/vikrantlabde/iso8583-Java经过一些修改后,我几乎可以很好地解析我的字段.... 我这样定义架构:

ISOSCHEMA.put("1","BITMAP");
ISOSCHEMA.put("2","NUM-2-19-0_0");
ISOSCHEMA.put("3","NUMERIC-0-6-0_0");
ISOSCHEMA.put("4","NUMERIC-0-12-0_0");
ISOSCHEMA.put("7","NUMERIC-0-10-0_0");
ISOSCHEMA.put("11","NUMERIC-0-6-0_0");
ISOSCHEMA.put("12","NUMERIC-0-6-0_0");
ISOSCHEMA.put("13","NUMERIC-0-4-0_0");
ISOSCHEMA.put("22","NUMERIC-0-3-0_0");
ISOSCHEMA.put("23","NUMERIC-0-3-0_0");
ISOSCHEMA.put("35","NUM-2-37-0_0");
ISOSCHEMA.put("41","FCHAR-0-8-0_0");
ISOSCHEMA.put("49","FCHAR-0-3-0_0");
ISOSCHEMA.put("55","NUM-3-999-0_0");

问题是字段 55 是一个二进制字段。标准文档说:

55 保留 ISO B 255 LLLVAR(ISO 文档)

我在解析为字段 55 打开位图的字符串时出错。

我从输出中得到: 820200409F36020004950500000000009A031409039C01005F2A0209789F02060000000005009F03060000000000009F10201F430200200000000000000000045895000000000000000000000000000000009F260840D26C4BA5577CFB9F2701809F370443DD7E879F1A0202509F3303E0B0C8

但我希望: 820200409F36020004950500000000009A031409039C01005F2A0201249F02060000000005009F03060000000000009F10201F430200200000000000000000045895000000000000000000000000000000009F260840D26C4BA5577CFB9F2701809F370443DD7E879F1A0202509F3303E0B0C8

转换后的iso payload长度也有很大的不同...

程序输出为: 303130307238060020C280C28200313636353433323131313232333334343535303030303030303030303030303030303031313031363138333432363030323339343133333433303130313630373130303133373635343332313131323233333434353564333131303232303030393238333030313031303238343031373430393132343233303832303230303430394633363032303030343935303530303030303030303030394130333134303930333943303130303546324130323039373839463032303630303030303030303035303039463033303630303030303030303030303039463130323031463433303230303230303030303030303030303030303030303034353839353030303030303030303030303030303030303030303030303030303030303030394632363038343044323643344241353537374346423946323730313830394633373034343344443745383739463141303230323530394633333033453042304338

我期望的是: 30313030723806002080820031363635343332313131323233333434353530303030303030303030303030303030303131303136313833343236303032333934313333343330313031363037313030313337363534333231313132323333343435353D33313130323230303039323833303031303130323834303137343039313234313135820200409F36020004950500000000009A031409039C01005F2A0201249F02060000000005009F03060000000000009F10201F430200200000000000000000045895000000000000000000000000000000009F260840D26C4BA5577CFB9F2701809F370443DD7E879F1A0202509F3303E0B0C8

一个建议是: 我必须从结果 byte[] 显式转换为十六进制,反之亦然。 它是:

String isoMessage = ISOUtil.hexString(packIsoMsg("0100", isofields).getBytes());

和:

unpackIsoMsg(new String(ISOUtil.hex2byte(isoMessage), "UTF-8"));

在这个类中定义这样的字段呢?我真的是标准的新手,但我来到这里是因为 jpos 不能在 Android 环境中工作。我也对最后提到的十六进制转换感到困惑。

非常感谢任何帮助... 亲切的问候。

最佳答案

DE55 被定义为一个标签滞后值 (TLV) 字段,它不是在正常的二进制/文本/或数字打包格式中,您通常会看到其余的 ISO-8583 消息,但它是在 ASN.1 BER-TLV/X.690-0207格式。

除非您考虑 BER-TLV,否则您将无法成功解压 DE55,除非它用于非 EMV/ token 化目的。一开始它让我震惊,因为我在想一些更直接的事情。请注意,有时这种格式的字段传输格式实际上比原始纯文本或其他二进制数据输出更长,因此它不是最有效的。

根据 ISO 规范,还有一些其他字段也可能使用 BER-TLV,但 DE55 是行业标准字段,将 BER-TLV 用于 EMV 功能,取代了 DE55 之前用作通用且很少使用的“费用字段” .

ISO-7816 规范及其 ISO-8583 详细用于 EMV 和标记化,还有其他引用和 quick guides如果您只是在寻找不那么深入的东西,就在那里。 ISO-7816 规范的所有卷都可以在互联网上免费公开找到,或者可以直接从 ISO organization 购买(spendy)如果您希望它们采用纯 ISO 格式。

我不熟悉您引用的具体 JAVA Git,但是 this one有一个关于如何使用 BER-TLV 的帮助页面。 Oracle 还有一个关于处理 BER-TLV 的页面 here . BinaryFoo 有一个 Git也可用。

出于初始测试的目的,如果您的数据只是测试数据(请勿使用生产数据!),您可以使用http://www.emvlab.org/tlvutils/验证您的结果。当我输入您的输入时,它会踢出您的预期输出。

关于java - 解析 iso8583 消息时出现问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28689378/

相关文章:

java - Thymeleaf 片段有时不起作用

Java套接字编程-流被卡住

android - Android 中始终可见的 View

c# - 比较两个大小相等的位图以确定它们是否相同的最快方法是什么?

android - 将图像转换为位图

java - 在 JSF 1.2 中使用动态生成的包

java - @Repository注解可以继承吗?

android - 如何获取并列出 Android 中所有已安装/可用的导航应用程序及其图标?

android - 使用 gradle 仅在一个构建变体上运行单元测试

android - 在 Android 上从服务器加载大图像