一个8583报文的简单例子
source: http://www.itpub.net/146961.html
yantong
一般会员
一个8583报文的简单例子
8583 是这样的,我举一个简单的例子。以64个域的报文来举例,域是什么我也说不清楚,你可以把它想象为医院放药的抽屉,一个抽屉预先定义好要放什么东西,比如伟哥,或者感冒冲剂,一般情况下定义放伟哥的抽屉最好永远放伟哥,不要放别的东西,当然你也可以放板蓝根,但这样的话容易出错,也不太规范。
数量是这么规定的,有三种情况:
首先是定量,也就是说定义好这个抽屉放30瓶伟哥,就放30瓶一瓶也不能多,一瓶也不能少。
其次是LLVAR,也就是说用1位字节定义数量,比如0x12表示里头放12瓶,当然你也可以理解为16+2=18瓶。但要是0x12表示12,那0x13就等于13,不要0x12=12 ,0x13=19
最后是LLLVAR,是2位字节表示数量,比如 0x01,0x04 = 104
域也就是这样的,一共有64个域,每个域预先定义了内容和长度
有一个叫做BITMAP的,也就是位图,定义了一个数据包里包含
了几个域。举个例子
20 00 38 00 00 00 00 34
你把它解开,排列一下
20 = 0010 0000
00 = 0000 0000
38 = 0011 1000
依次类推,得到一串数字
0010 0000 0000 0000 0011 1000 0000 0000 0000 0000 0000 0000 0000 0000 0011 0100
然后从左到右数一下里头含有1的是那几位,上面的例子我们得到
3 19 20 21 59 60 62 ,这几位含有1。也就是说接下来的报文包含有这几个域。
好了说了那么多,我们来做一个简单的例子比如消费交易,需要上送交易类型,卡号等等,定义如下
卡号 第2域 LLVAR BCD [**************]2
交易类型 第3域 长度6 BCD 900000
金额 第4域 长度12 BCD 100分
时间 第7域 长度8 BCD 20030802
2磁道信息 第35域 LLVAR ASCII 123456
3磁道信息 第36域 LLLVAR BCD 123456001
商户号 第41域 LLVAR ASCII 98765432
好了我们现在开始打包,首先按照长度和类型把上面的数据处理一下
卡号 [***********]
交易类型 900000
金额 [1**********]0
时间 20030802
2磁道 [1**********]536
3磁道 [1**********]01
商户号 [***********]
接下来我们按照域信息生成位图
因为有第2域,所以第二个位置是1,由第三域,所以第三个位置
是1,。。。
依此类推得到一串数字
0111 0010 0000 0000 0000 0000 0000 0000 0011 0000 1000 0000 0000 0000 0000 0000
转换过来,就是
72 00 00 00 30 80 00 00 这个就是BITMAP了
然后把上面的数据按照BITMAP+每个域的内容,依次排列
就得到这个包的内容了
[***********][***********][**************]0
[***********][***********][**************]32
前头再加上TPDU和MSGID就是最后的数据包
很简单把,解包也一样的。
写得不好,让各位见笑了。
******
yantong
一般会员
不对,第二
域是卡号,是BCD的,LLVAR不代表BCD或者ASC
接口是这样定义的
位元 字段名称 属性 长度 包中长度 包中格式
2 卡号 LLVAR ..19 ..11 BCD
3 处理代码 N 6 3 BCD
4 交易金额 N 12 6 BCD
看“包中格式”这一段。
TPDU是一串10位的数字,跟网控器有关
网控器是这样的一台设备。它里头有很多张卡
有些卡负责接受终端通过电话或者别的途径传送上来的数据包,叫做下联卡,
有些卡负责把下联卡的数据通过串口或者网线转发给后台前置机,叫做上联卡
tpdu的特定位定义了下联卡收到数据以后,转发到哪一块上联卡。
上联卡根据tpdu相关信息把数据转发给特定的主机(因为现在的上联卡比如LET61可以指向很多台主机的),tpdu一般银行都是6000000000,也有6000060000或者其他,具体问银行科技部门就可以了。
MSGID表示这个报文是做什么的,比如是消费还是查余额。接口定义都有的
比如 0200或者0800之类。
由 yantong 于 03-08-05 14:25 最后编辑