8583报文手动组包——详细分析每个示范域

8583报文手动组包——详细分析每个示范域

 

8583报文作为一种应用较广的报文,有它独特的格式。

网上有关8583报文的说明很多。但涉及到每个域的详细例子就较少了。这里列出各个域的详细例子,供参考。

8583报文:

报文组成:

报文头【长度(2字节)+TPDU(5字节)+报文版本号(2字节)】+信息类型+位图+数据

TPDU: 6000100000

报文版本号:0100

信息类型:0080 

报文长度:整体报文长度 -报文头中的2字节长度。如8583整体报文长度为100,那么报文长度为98.用两字节的BCD码表示(16进制)为0062。

报文中容易出错的在于银联规范中的各种数据格式,定长、变长、ASCII变长、以及TLV格式等。在组包或者解包前,仔细看规范是十分重要的。

以下主要是针对各个域单独组包和多个域组包的情况举例。

多域组包

手动组装的8583报文:

0072600010000001000800203801000404000880000000000110101112240009303030313531000800350004343136310009303030303031303031

分析组包过程:

0072(长度)

6000100000(TPDU)

0100(版本号)

0800(信息类型)

2038010004040008(64位图)

800000(3域)

000001(11域)

101011(12域)

1224(13域)

0009(24域)

303030313531(38域)

00080035000434313631(46域)

0009303030303031303031(61域)

按顺序拼接起来即可。

详细的分析,在单独域组包中可以看到。

单独域组包

2域单独组包:

格式:变长,LLVAR

类型:N..19,压缩时使用1字节BCD表示的长度 + 用右靠BCD码表示最大10个字节的变长域。

二进制:0100 0000 0000 0000 0000 0000 0000 0000 0000 0000 0000 0000 0000 0000 0000 0000

十六进制(BCD码>1001加6):4000000000000000

2域内容:6333021402021781,按规范转为:166333021402021781

计算报文长度:0034

组装8583报文:00346000100000010000804000000000000000166333021402021781

3域单独组包:

格式:定长

类型:N6,压缩时用BCD码表示的3个字节的定长域。

二进制:0010 0000 0000 0000 0000 0000 0000 0000 0000 0000 0000 0000 0000 0000 0000 0000

十六进制(BCD码>1001加6):2000000000000000

3域内容:800000 ,按规范转为:800000

报文长度:0028

组装8583报文:00286000100000010000802000000000000000800000

4域单独组包:

格式:定长

类型:N12,压缩时用BCD码表示的6个字节的定长域。

二进制:0001 0000 0000 0000 0000 0000 0000 0000 0000 0000 0000 0000 0000 0000 0000 0000

十六进制(BCD码>1001加6):1000000000000000

4域内容:1.01,按规范转为:000000000101

报文长度:002E

组装8583报文:002E6000100000010000801000000000000000000000000101

7域单独组包:

n10,10位定长数字字符

格式:MMDDhhmmss

二进制:0000 0010 0000 0000 0000 0000 0000 0000 0000 0000 0000 0000 0000 0000 0000 0000

十六进制(BCD码>1001加6):0200000000000000

7域内容:0228102030,按规范转为:0228102030

报文长度:002C

组装8583报文:002C60001000000100008002000000000000000228102030

11域单独组包:

格式:定长

类型:N6,压缩时用BCD码表示的3个字节的定长域。

二进制:0000 0000 0010 0000 0000 0000 0000 0000 0000 0000 0000 0000 0000 0000 0000 0000

十六进制(BCD码>1001加6):0020000000000000

11域内容:000001,按规范转为:000001

报文长度:0028

组装8583报文:00286000100000010000800020000000000000000001

12域单独组包:

格式:定长,HHmmss

类型:N6,压缩时用BCD码表示的3个字节的定长域

二进制:0000 0000 0001 0000 0000 0000 0000 0000 0000 0000 0000 0000 0000 0000 0000 0000

十六进制(BCD码>1001加6):0010000000000000

12域内容:203012,按规范转为:203012

报文长度:0028

组装8583报文:00286000100000010000800010000000000000203012

13域单独组包:

格式:定长,MMDD

类型:N4,压缩时用BCD码表示的2个字节的定长域。

描述:交易在终端上发生的时间。

二进制:0000 0000 0000 1000 0000 0000 0000 0000 0000 0000 0000 0000 0000 0000 0000 0000

十六进制(BCD码>1001加6):0008000000000000

13域内容:0430,按规范转为:0430

报文长度:0024

组装8583报文:002460001000000100008000080000000000000430

14域单独组包:

格式:定长,MMYY

类型:N4,压缩时用BCD码表示的2个字节的定长域。

描述:卡的有效期,月月年年

二进制:0000 0000 0000 0100 0000 0000 0000 0000 0000 0000 0000 0000 0000 0000 0000 0000

十六进制(BCD码>1001加6):0004000000000000

14域内容:0415,按规范转为:0415

报文长度:0024

组装8583报文:002460001000000100008000040000000000000415

15域单独组包:

格式:定长, MMDD

类型:N4,压缩时用BCD码表示的2个字节的定长域。

描述:清算日期(Date Of Settlement),月月日日

二进制:0000 0000 0000 0010 0000 0000 0000 0000 0000 0000 0000 0000 0000 0000 0000 0000

十六进制(BCD码>1001加6):0002000000000000

15域内容:1229,按规范转为:1229

报文长度:0024

组装8583报文:002460001000000100008000020000000000001229

32域单独组包:

格式:变长,LLNUM

类型:N..11,压缩时使用1字节BCD表示的长度 + 用右靠BCD码表示最大11个字节的变长域。

描述:受理机构标识码。该代理机构应是已被批准入网,能为商户提供收单服务的入网机构。

二进制:0000 0000 0000 0000 0000 0000 0000 0001 0000 0000 0000 0000 0000 0000 0000 0000

十六进制(BCD码>1001加6):0000000100000000

32域内容:2001,按规范转为:042001

报文长度:0028

组装8583报文:00286000100000010000800000000100000000042001

34域单独组包:

格式:变长,LLVAR

类型:N..28,1个字节BCD长度值 + 最大28个字节的变长ASCII。

描述:扩展主账号信息域

二进制:0000 0000 0000 0000 0000 0000 0000 0000 0100 0000 0000 0000 0000 0000 0000 0000

十六进制(BCD码>1001加6):0000000040000000

34域内容:198809,按规范转为:06313938383039

报文长度:0030

组装8583报文:0030600010000001000080000000004000000006313938383039

35域单组组包:

格式:变长,LLVAR

类型:Z..48(加密后),1个字节BCD长度值 + 用右靠BCD码表示的最大24个字节的第二磁道数据。

描述:写在卡二磁道的数据。

二进制:0000 0000 0000 0000 0000 0000 0000 0000 0010 0000 0000 0000 0000 0000 0000 0000

十六进制(BCD码>1001加6):0000000020000000

35域内容:EB5B9DB3618B836C1E334C8EBD8AAFA0C0777471F9F41B19,按规范转为:24EB5B9DB3618B836C1E334C8EBD8AAFA0C0777471F9F41B19

报文长度:0054

组装8583报文:0054600010000001000080000000002000000024EB5B9DB3618B836C1E334C8EBD8AAFA0C0777471F9F41B19

36域单独组包:

格式:变长,LLLVAR

类型:Z...112(加密后),2个字节BCD长度值 + 用右靠BCD码表示的最大56个字节的第三磁道数据。

描述:写在卡三磁道的数据。

二进制:0000 0000 0000 0000 0000 0000 0000 0000 0001 0000 0000 0000 0000 0000 0000 0000

十六进制(BCD码>1001加6):0000000010000000

36域内容:EB5B9DB3618B836C1E334C8EBD8AAFA0C0777471F9F41B19,按规范转为:0024EB5B9DB3618B836C1E334C8EBD8AAFA0C0777471F9F41B19

报文长度:0056

组装8583报文:005660001000000100008000000000100000000024EB5B9DB3618B836C1E334C8EBD8AAFA0C0777471F9F41B19

37域单独组包:

格式:定长

类型:AN12,12个字节的定长ASCII。

二进制:0000 0000 0000 0000 0000 0000 0000 0000 0000 1000 0000 0000 0000 0000 0000 0000

十六进制(BCD码>1001加6):0000000008000000

37域内容:11112233,按规范转为:303030303131313132323333

报文长度:003A

组装8583报文:003A6000100000010000800000000008000000303030303131313132323333

41域单独组包:

格式:定长

类型:N8,8个字节的定长ASCII

描述:定义在收单单位中定义一个服务终端的标识码

二进制:0000 0000 0000 0000 0000 0000 0000 0000 0000 0000 1000 0000 0000 0000 0000 0000

十六进制(BCD码>1001加6):0000000000800000

41域内容:12345678,按规范转为:3132333435363738

报文长度:0032

组装8583报文:003260001000000100008000000000008000003132333435363738

42域单独组包:

格式:定长

类型:ANS15,15个字节的定长ASCII

描述:在本地和网络中定义交易单位(商户)的编码

二进制:0000 0000 0000 0000 0000 0000 0000 0000 0000 0000 0100 0000 0000 0000 0000 0000

十六进制(BCD码>1001加6):0000000000400000

41域内容:821024512345678,按规范转为:383231303234353132333435363738

报文长度:0040

组装8583报文:00406000100000010000800000000000400000383231303234353132333435363738

46域单独组包:

格式:变长,LLLVAR

类型:ANS..255,2个字节BCD长度值 + 最大128个字节的ASCII。

描述:该域用于处理TLV数据

二进制:0000 0000 0000 0000 0000 0000 0000 0000 0000 0000 0000 0100 0000 0000 0000 0000

十六进制(BCD码>1001加6):0000000000040000

46域内容:0000#trans_type#99,按规范转为:0006000000023939

报文长度:0032

组装8583报文:003260001000000100008000000000000400000006000000023939

52域单独组包:

格式:定长

类型:B64,8个字节的定长二进制数

描述:用户在服务终端上交易用于识别用户合法性的一些数字

二进制:0000 0000 0000 0000 0000 0000 0000 0000 0000 0000 0000 0000 0001 0000 0000 0000

十六进制(BCD码>1001加6):0000000000001000

52域内容:5EF0F6C66C3ED34E,按规范转为:5EF0F6C66C3ED34E

报文长度:0032

组装8583报文:003260001000000100008000000000000010005EF0F6C66C3ED34E

55域单独组包:

格式:变长,LLLVAR

类型:ANS..255, 2个字节BCD长度值 + 最大128个字节的BCD数据

描述:本域为IC卡交易使用

二进制:0000 0000 0000 0000 0000 0000 0000 0000 0000 0000 0000 0000 0000 0010 0000 0000

十六进制(BCD码>1001加6):0000000000000200

52域内容:9F260879CC8EC5A09FB9479F2701809F100807010199A0B806019F3704000000009F360201C2950500001800009A031205089C01609F02060000000000005F2A02015682027D009F1A0201569F03060000000000009F3303E0F0F09F34036003029F3501119F1E0832303033313233318405FFFFFFFFFF9F090220069F4104000000019F74064543433030319F631030313032303030308030303030303030,按规范转为:03189F260879CC8EC5A09FB9479F2701809F100807010199A0B806019F3704000000009F360201C2950500001800009A031205089C01609F02060000000000005F2A02015682027D009F1A0201569F03060000000000009F3303E0F0F09F34036003029F3501119F1E0832303033313233318405FFFFFFFFFF9F090220069F4104000000019F74064543433030319F631030313032303030308030303030303030

报文长度:0164

组装8583报文:0164600010000001000080000000000000020001599F260879CC8EC5A09FB9479F2701809F100807010199A0B806019F3704000000009F360201C2950500001800009A031205089C01609F02060000000000005F2A02015682027D009F1A0201569F03060000000000009F3303E0F0F09F34036003029F3501119F1E0832303033313233318405FFFFFFFFFF9F090220069F4104000000019F74064543433030319F631030313032303030308030303030303030

61域单独组包:

bitmap(64位图):

二进制:0000 0000 0000 0000 0000 0000 0000 0000 0000 0000 0000 0000 0000 0000 0000 1000

十六进制(BCD码>1001加6):0000000000000008

61域内容:  000001001,按规范转换为:0009303030303031303031

计算报文长度:0038

组装8583报文:003860001000000100008000000000000000080009303030303031303031 

猜你喜欢

转载自blog.csdn.net/tuxedolinux/article/details/81212035