java des 偏移_Java-IBM 3624引脚偏移生成

我正在使用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)进行交叉检查时,偏移和生成的引脚不匹配.我哪里出问题了?

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值