我正在使用IBM 3624算法进行引脚生成,然后从中进行偏移.这是IBM Website的算法:
我不确定顺序,必须使用输入数据.例如,该算法需要验证数据(起始位置,长度,PAN焊盘字符和引脚长度),十进制表(0123456789012345),引脚,水平和峰值. PDK.
编辑:这是输入数据格式-
PAN(帐号或卡号):16位十六进制字符串.
引脚(通常为4位,但可以根据要求进行更改):4位数字(要从十进制表中替换的十六进制值)
PDK(PAN随附的加密密钥):32位数字
开始位置和长度:要从PAN中选择的数字,最后一位是校验位,将被忽略. PAN的这些选定的数字随后被填充回16位.
填充字符:单个字符(十六进制数字).
这是我用来执行此操作的代码:
public static void CalculatePINOffset(String PAN, String Pin, String PDKkey, String DecTab, int StartPos, int Length,
char PadChar) throws Exception{
int PANLength = PAN.length();
if(Length != (PANLength - StartPos)){
throw new Exception(
"Invalid 'Start Pos and Length' format.");
}
//Padding the PAN before Start POS with Pad Chars back to 16 digits.
String block = ISOUtil.padleft(PAN.substring(StartPos, Length + (StartPos - 1)), PAN.length(), PadChar);
/*
* Doing encryption stuff on block with PDKKey.
* The execute function basically encrypts block and PDKKey, and any algorithm could do the work.
*/
String result = execute(block , PDKkey, "2TDES");
Map decTab = new HashMap();
decTab.put('A', '0');
decTab.put('B', '1');
decTab.put('C', '2');
decTab.put('D', '3');
decTab.put('E', '4');
decTab.put('F', '5');
//Replacing Hex Characters with numbers from Decmalization table.
char[] Inpin = result.substring(0, 4).toCharArray();
for(int i = 0; i < Inpin.length; i++){
if(decTab.containsKey(Inpin[i])){
Inpin[i] = decTab.get(Inpin[i]);
}
}
result = new String(Inpin);
System.out.println("Intermediate PIN: "+result);
//Calculating offset from Intermediate Pin.
int[] Offset = new int[4];
int Cpin;
int Ipin;
for(int i = 0; i < result.length(); i++){
Ipin = Integer.parseInt(result.substring(i, i+1));
Cpin = Integer.parseInt(Pin.substring(i, i+1));
if((Cpin - Ipin) >= 0){
Offset[i] = (Cpin - Ipin);
}
else{
Offset[i] = (Ipin - Cpin)%10;
}
}
String PinOffset = Arrays.toString(Offset);
System.out.println("Pin Offset: " + PinOffset);
}
注意:我不是在寻找代码或实现.我提供了此代码段,以更好地解释使用顺序.可以帮助我的是正确的加密顺序,验证数据的使用以及十进制表.
当使用开源工具(如BP-Tools)进行交叉检查时,偏移和生成的引脚不匹配.我哪里出问题了?