银行常用加密算法PINBlock加密

时间:2023-01-05 19:07:08

1.首先知道PIN的数据格式和如何获取PIN

PIN的格式应符合ANSI X9.8 Format(带主账号信息)

PIN的长度为4-12位格式:LV

位置

长度

内容

1

1字节

PIN长度

2

7字节

4-12位PIN(每个字符占4个BIT,不足右补F)

若只得到PIN码,则按照如下格式压缩成PIN格式

PIN长度(1 个字节) 4-12位PIN(每个字符占4个BIT,不足右补F)(7 个字节)
如:0x06123456FFFFFFFFFF 

2.PAN数据格式

PAN是从主账号的最后一位检验位前向左取12位,此中数据都是BCD码格式

位置

长度

内容

1

2字节

%H0000

2

6字节

取主账号的右边数第二位开始向左12 位


0000(2个字节) 12位PAN(每个字符占4个BIT)(6 个字节)
如:主账号:123456789012345678

       取得PAN:0x0000678901234567

3.PIN和PAN异或得到PINBLock

将Hex格式的PIN和PAN异或即可得到要求结果

PIN: 0x06123456FFFFFFFF 

PAN:0x0000678901234567

异或: 0x061253DFFEDCBA98

4.根据需要与对应密钥加密即可得最终的加密PINBLOCK数据