C# SHA-256 vs. Java SHA-256. Different results?

前端 未结 5 1687
无人共我
无人共我 2021-02-10 09:16

I want to convert a some code which is in Java to C#.

Java Code:

  private static final byte[] SALT = \"NJui8*&N823bVvy03^4N\".getBytes();

  public         


        
相关标签:
5条回答
  • 2021-02-10 09:49
    public static String getEncryptedPassword(String clearTextPassword) throws NoSuchAlgorithmException{
    
        MessageDigest md = MessageDigest.getInstance("SHA-256");
        md.update(clearTextPassword.getBytes(StandardCharsets.UTF_8));
        byte[] digest = md.digest();
        String hex = String.format("%064x", new BigInteger(1, digest));
        String st = new String(hex.toUpperCase());
        for (int i = 2; i < (hex.length() + hex.length() / 2) - 1 ;) {
            st = new StringBuffer(st).insert(i, "-").toString();
                i = i + 3;        
        }
        return st ; 
    
    }
    

    You can use the following java to match that of C#

    0 讨论(0)
  • 2021-02-10 09:58

    You didn't really write how you called the SimpleHash class - with which parameters and such.

    But note that its ComputeHash method has in its documentation:

    Hash value formatted as a base64-encoded string.

    Your class instead formats the output in hexadecimal, which will obviously be different.

    Also, the salt is in SimpleHash interpreted as base64, while your method interprets it as ASCII (or whatever your system encoding is - most probably something ASCII-compatible, and the string only contains ASCII characters).

    Also, the output in SimpleHash includes the salt (to allow reproducing it for the "verify" part when using random salt), which it doesn't in your method.

    (More points are already mentioned by the other answers.)

    0 讨论(0)
  • 2021-02-10 09:59

    The String.getBytes method encodes the string to bytes using the platform's default charset, whereas the example code you linked uses UTF-8.

    Try this:

    digest.update(secret.getBytes("UTF-8"));
    

    Secondly, the Integer.toHexString method returns the hexadecimal result with no leading 0s.

    0 讨论(0)
  • 2021-02-10 10:02

    The C# code you link to also uses salt - but the Java code does not. If you use salt with once, but not the other, then the results will be (and should be!) different.

    0 讨论(0)
  • 2021-02-10 10:11
    hexString.append(Integer.toHexString(0xFF & hash[i]));
    

    You are building the hash string incorrectly. Integer.toHexString does not include leading zeros, so while Integer.toHexString(0xFF) == "FF", the problem is that Integer.toHexString(0x05) == "5".

    Suggested correction: String.format("%02x", hash[i] & 0xFF)

    0 讨论(0)
提交回复
热议问题