1

我正在尝试将 java api 转换为 cd1 api 的加密...我在 java 中有这个方法:

private static byte[] encodePassword(String password,String salt) throws UnsupportedEncodingException 
         {                 
    String mergedPasswordAndSalt =mergePasswordAndSalt(password, salt);
    SHA512Digest digester =new  SHA512Digest();        
    byte[] hash = new byte[digester.getDigestSize()];   
             System.out.println("init hash= "+Base64.encode(hash));
    try {
        hash = mergedPasswordAndSalt.getBytes("UTF-8");  
        System.out.println("init merged= "+Base64.encode(hash));
        digester.doFinal(hash,0);  
          System.out.println("after");
    } catch (Exception ex) {
        System.out.println("Exception");                 
    }          
    for (int  i = 1; i < ITERATIONS; ++i) {            
        digester.doFinal(Bytes.concat(hash, mergedPasswordAndSalt.getBytes("UTF-8")),0); 
    }                 
    return hash;
}

我正在尝试以与 MessageDigest(在 java 中)相同的方式使用 SHA512Digest:

private static byte[] encodePassword(String password,String salt) throws UnsupportedEncodingException 
         {                 
    String mergedPasswordAndSalt =mergePasswordAndSalt(password, salt);
    SHA512Digest digester =new  SHA512Digest();

    byte[] hash = null;
    try {
        hash = mergedPasswordAndSalt.getBytes("UTF-8");           
        digester.doFinal(mergedPasswordAndSalt.getBytes("UTF-8"),0);            
    } catch (Exception ex) {
        System.out.println("Exception");                 
    }                    
    for (int i = 1; i < ITERATIONS; ++i) {            
        digester.doFinal(Bytes.concat(hash, mergedPasswordAndSalt.getBytes("UTF-8")),0);           
    }                   
    return hash;
}

该库已在我的项目中建立,但 doFinal 不起作用...我无法将 java 转换为代号,当我加密的结果返回未由 doFinal 修改的初始哈希时

    init hash= AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA
AAAAAAAAAA==
init merged= MDAwMHtUZXdSLm1ldE9yTldrV1JTcWVJaHV4ejAvN2ZjeS5HUGIvS1l5c1BybkFZfQ==
Exception

and the method return Sha512{salt='TewR.metOrNWkWRSqeIhuxz0/7fcy.GPb/KYysPrnAY', hash='z4PhNX7vuL3xVChQ1m2AB9Yg5AULVxXcg/SpIdNs6c5H0NE8XYXysP+DGNKHfuwvYw=='}
4

1 回答 1

0

我们只需要创建一个散列当前输入并返回该散列以在下一次迭代中使用的方法:

public static byte[] digestt(byte[] bytes) {
Digest digest = new SHA512Digest();
byte[] resBuf = new byte[digest.getDigestSize()];

digest.update(bytes, 0, bytes.length);
digest.doFinal(resBuf, 0);
return resBuf;
}
于 2018-05-05T11:08:58.257 回答