解析ISO8583报文实例

转载 2015年11月19日 19:16:14

本篇文章参考了中国银联POS终端规范,所以如有不明白的可以去我的资源里面下载。


现在我们有ISO8583报文如下(十六进制表示法):

60 00 03 00 00 60 31 00 31 07 30 02 00 30 20 04 C0 20 C0 98 11 00 00 00 00 00 00 00 00 01 00 03 49 02 10 00 12 30 62 25 82 21 12 99 63 01 5D 15 11 10 10 00 00 35 36 38 35 32 33 31 34 32 33 35 32 31 34 35 32 36 38 35 39 32 33 36 31 35 36 C6 24 83 4D 36 7E 9E 9E 20 00 00 00 00 00 00 00 00 13 22 00 00 08 00 05 00 36 37 41 32 32 39 39 41


第一步

POS终端上送POS中心的消息报文结构包括TPDU、报文头和应用数据三部分:

 

——TPDU说明:长度为10个字节,压缩时用BCD码表示为5个字节长度的数值。

——报文头说明:总长度为12字节,压缩时用BCD码表示为6个字节长度的数值。

——应用数据说明:一般长度都是4个字节,压缩时用BCD码表示为2个字节的长度的数值。

所以上述报文中前五个字节为TPDU,即60 00 03 00 00

报文头占用六个字节,即 60 31 00 31 07 30

应用数据占用2个字节,即 02 00 也就是"0200"

——0200金融类请求消息:

●   POS查询请求。

●   POS消费请求。

●   POS消费撤销请求。

●   POS预授权完成(请求)请求。

●   POS预授权完成撤销请求。

●   电子现金脱机消费请求。

●   分期付款消费请求。

●   分期付款消费撤销请求。

●   基于PBOC电子钱包/电子现金的IC圈存类交易请求。

●   磁条卡现金充值请求。

第二步

分析位图:

首先取第十四个字节,即0x30 ,转化为二进制为0011 0000,在该字节的第一位为0(从左往右)表示当前报文中只需包括64个域,也就是从当前字节开始连续8个字节为位图(包括当前字节),如要包括128个域,该位为1。

现在进入关键的位图分析,现在我们取到了表示位图的8个字节即30 20 04 C0 20 C0 98 11,转为二进制为

00110000 00100000 00000100 11000000 00100000 11000000 10011000 00010001

位图中为1的位置即代表相应的域,在上面的二进制位中从左往右有第3位、第4位、第11位、第22位、第25位、第26位、第35位、第41位、第42位、第49位、第52位、第53位、第60位、第64位。

下面开始这些域中的数据,首先分析3域,3域为交易处理码,压缩成BCD码后占定长3个字节,我们从位图所占的8个字节后开始连续取3个字节,即 00 00 00,解压后即为“000000”,具体代表含义这里就不叙述了。

4域为交易金额,压缩成BCD码后占定长6个字节,同理取6个字节,即00 00 00 00 00 01,也就是金额0.01元,具体转换参考银联规范。

11域为受卡方系统跟踪号(流水号),压缩成BCD码占定长3个字节,同理取3个字节,即00 03 49,即000349。

22域为服务点输入方式码,压缩成BCD码占定长2个字节,同理取2个字节,即02 10,由于22域本身只占3个字节,压缩时左靠,右补0,所以转换为“021”,具体含义不再叙述。

25域为服务点条件码,压缩成BCD码占定长1个字节,同理取1个字节,即00,转换为“00”,“00”代表正常提交。

26域为服务点PIN获取码,压缩成BCD码占定长1个字节,同理取1个字节,即12,转换为“12”,表示服务点设备所允许输入的个人密码明文的最大长度为12。

解下来的35域由于不是定长,所以处理方法不同,先取一个字节,即30,转换为“30”,表示第二磁道的数据占用30个字节,取连续15个字节即62 25 82 21 12 99 63 01 5D 15 11 10 10 00 00,这里不对这串数据进行说明了。

41域为受卡机终端标识码,占8个字节的定长域,取35 36 38 35 32 33 31 34。

42域为受卡方标识码,占15个字节的定长域,取32 33 35 32 31 34 35 32 36 38 35 39 32 33 36。

49域为交易货币代码,占3个字节的定长域,取31 35 36。

52域为个人标识码数据,占8个字节的定长二进制数域,取C6 24 83 4D 36 7E 9E 9E。

53域为安全控制信息,压缩成BCD码占8个字节定长域,取20 00 00 00 00 00 00 00。

60域为自定义域,为不定长域,先取长度(压缩成BCD码占两个字节),即00 13,转换为13即占60域占13个字节,压缩成BCD码占7个字节,取22 00 00 08 00 05 00。

64域为报文鉴别码,占定长8个字节,取最后八个字节36 37 41 32 32 39 39 41。

ISO8583报文工具类(组装和解析报文)

很久没来csdn了。现在的工作地点在银行,妈的,不让上网啊。 写写博客其实是对自己知识的总结,这么长时间了,也该写点东西了。接触银行的项目,避免不了 遇上8583报文。具体介绍就不细讲了,这个网上一大...
  • lushuaiyin
  • lushuaiyin
  • 2013年11月06日 21:00
  • 11360

ISO8583报文中的编、解码总结

1.pos收单流程从POS机的角度看,一个典型的收单交易流程为:1. 根据报文格式进行组包,向后台发起交易请求; 2. 后台收到请求后解包进行验证,验证完成后重新组包返回应答报文; 3. POS终端收...
  • youyu_torch
  • youyu_torch
  • 2017年01月17日 14:16
  • 14215

银联则及终端iso8583报文规范的理解

面对标准iso8583,相信有很多的人知道,也看过相关的文档。初学者面对iso8583接口文档,首先需要弄清楚,是关于终端则的还是关于银联平台则的。     如果你是针对终端的则一般是《销售点终端(P...
  • hancker
  • hancker
  • 2016年06月11日 17:38
  • 1779

解析ISO8583报文实例

本篇文章参考了中国银联POS终端规范。 现在我们有ISO8583报文如下(十六进制表示法): 60 00 03 00 00 60 31 00 31 07 30 02 00 30 20 04...
  • u012086167
  • u012086167
  • 2014年07月24日 13:37
  • 696

Andorid开发之银联ISO8583报文格式、组包和解包过程、TPDU、位图计算过程

8583:8583协议是基于ISO8583报文国际标准的包格式的通讯协议,8583包最多由128个字段域组成,每个域都有统一的规定,并有定长与变长之分。8583包前面一段为位图,它是打包解包确定字段域...
  • qq_33750826
  • qq_33750826
  • 2016年12月19日 16:43
  • 2968

谈谈8583报文的使用及测试

ISO8583报文在金融行业可谓是声名显赫,8583报文是一个国际标准的包格式,其重要性阿堂就不用多说了,网上有很多的介绍,不过对于一个从未接触过8383报文的新手来说,还是很有难度的。它主要是用来解...
  • qq445803843
  • qq445803843
  • 2015年04月08日 12:22
  • 584

ISO8583报文协议——很容易理解

我刚进入金融行业时,就知道了IS08583报文协议,我想可能我还没进入这个行业都已经听过了,可知ISO8583的影响力有多大了。最初刚接触它时,确实对其中的一些细节概念不是很清晰,对有些地方比较迷惑。...
  • yuan_hong_wei
  • yuan_hong_wei
  • 2015年10月15日 10:03
  • 5864

关于银联则及终端则iso8583报文规范的理解

面对标准iso8583,相信有很多的人知道,也看过相关的文档。初学者面对iso8583接口文档,首先需要弄清楚,是关于终端则的还是关于银联平台则的。     如果你是针对终端的则一般是《销售点终...
  • slj_win
  • slj_win
  • 2014年04月10日 22:16
  • 4097

ISO8583报文(二)

金融行业的业务包括有关金融交易的电子信息交换。应用规范的约定通常局限在专业级别上。ISO8583国际标准设计了一个保证在采用不同应用规范的系统间能够进行信息交换的界面规范。各应用规范可保持在专用级别上...
  • chy555chy
  • chy555chy
  • 2016年08月01日 11:11
  • 826

ISO8583报文64域

调试ISO8583报文每个域
  • kingyc123456789
  • kingyc123456789
  • 2017年05月26日 17:22
  • 575
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:解析ISO8583报文实例
举报原因:
原因补充:

(最多只允许输入30个字)