1

我正在尝试从考勤时钟设备(DeviceName=TA8020)通过 UDP 接收的二进制数据中解压缩以下结构:

 typedef struct _AttLog_{
 Int PIN; //U16 PIN, user number
 char verified;// verifying method
 time_t time_second; //time, time code is user-defined time code.
 char status;// attendance state
 }TAttLog, *PAttLog;

尝试像这样解压缩数据:

uid, state, timestamp, space = unpack( '24s1s4s11s', attendancedata.ljust(40)[:40] )
print "%s, %s, %s, %s" % (uid, state, space, decode_time( int( reverseHex( timestamp.encode('hex') ), 16 ) ) )

产生以下结果:

5, ,   , 2016-02-13 11:55:36

uid 和时间戳是正确的,但我无法获得 char verify 和 char status 的正确值,因为您可以看到像上面那样解压结构,它们返回为空。

当尝试解压 char status 和 char 单独验证时,如下所示:

state = unpack('>3c',attendancedata[17:20])
space = unpack('>2c',attendancedata[21:23])

产量:

statem ('\x00', '\x00', '\x00')
statev 0

每次都不是正确的值。(通过查看考勤设备的Web界面日志来验证)

开箱如:

oneSet = unpack('24s1s4s11s',attendancedata.ljust(40)[:40])

产生: ('5\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\ x00','\x01','h\x1b\xe0\x1e','\x01\x00\x00\x00\x00\x00\x00\x00\x00\xb2\x00')

API 文档提供了如下详细信息:

只能使用 read 命令读取所有考勤日志。考勤日志可以以长模式或短模式压缩。压缩方法(如果现在正在读取char *Buffer,则手将在第一个字节)是:前2个字节用于存储用户PIN(U 16 PIN),使用第三个字节的前三位用于存储验证状态。第 4 和第 5 位存储验证方法。第 6 位存储短时和长时符号。如果是短时间格式,时间值是第三个字节和第三个字节的最后两位加上最近的长时间值(因此,时间格式存储为前一个长时间值的失准值)。然后根据时间编码方式(参考用户自定义编码方式)解码得到正确的时间。

任何帮助将非常感激。

4

1 回答 1

0

好的,我想通了:

state = unpack('c',attendancedata[29:30])

是我需要的值。

于 2016-02-13T18:14:11.973 回答