Skip to content

Instantly share code, notes, and snippets.

@maqnouch
Created September 22, 2016 10:37
Show Gist options
  • Save maqnouch/8dd60812c2ef938bc73a947dabcfd506 to your computer and use it in GitHub Desktop.
Save maqnouch/8dd60812c2ef938bc73a947dabcfd506 to your computer and use it in GitHub Desktop.
Java code for calculating HMAC-SHA1 Signatures
import java.security.InvalidKeyException;
import java.security.NoSuchAlgorithmException;
import java.security.SignatureException;
import java.util.Formatter;
import javax.crypto.Mac;
import javax.crypto.spec.SecretKeySpec;
/**
* The <tt>HmacSha1Signature</tt> shows how to calculate
* a message authentication code using HMAC-SHA1 algorithm.
*/
public class HmacSha1Signature {
private static final String HMAC_SHA1_ALGORITHM = "HmacSHA1";
private static String toHexString(byte[] bytes) {
Formatter formatter = new Formatter();
for (byte b : bytes) {
formatter.format("%02x", b);
}
return formatter.toString();
}
public static String calculateRFC2104HMAC(String data, String key)
throws SignatureException, NoSuchAlgorithmException, InvalidKeyException
{
SecretKeySpec signingKey = new SecretKeySpec(key.getBytes(), HMAC_SHA1_ALGORITHM);
Mac mac = Mac.getInstance(HMAC_SHA1_ALGORITHM);
mac.init(signingKey);
return toHexString(mac.doFinal(data.getBytes()));
}
public static void main(String[] args) throws Exception {
String hmac = calculateRFC2104HMAC("data", "key");
System.out.println(hmac);
assert hmac.equals("104152c5bfdca07bc633eebd46199f0255c9f49d");
}
}
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment