hmac消息加密,但使用我们自己的密钥

时间:2010-09-23 17:02:27

标签: java encryption cryptography hmac

try { // Generate a key for the HMAC-MD5 keyed-hashing algorithm
     KeyGenerator keyGen = KeyGenerator.getInstance("HmacMD5");
     SecretKey key = keyGen.generateKey(); 
    // Generate a key for the HMAC-SHA1 keyed-hashing algorithm 
keyGen = KeyGenerator.getInstance("HmacSHA1"); 
        key = keyGen.generateKey(); } 
        catch (java.security.NoSuchAlgorithmException e) { }

上面的代码将为我们提供使用HMAC消化消息的密钥。现在我想在java中实现HMAC逻辑,其中密钥将由用户给出。 有什么想法吗?

1 个答案:

答案 0 :(得分:1)

使用提供的用户密钥构建KeySpec(如果是字节数组,则为SecretKeySpec;如果是密码,则为PBEKeySpec),然后使用SecretKeyFactory把它变成SecretKey