Python实现的HMacMD5加密算法示例
本文实例讲述了Python实现的HMacMD5加密算法。分享给大家供大家参考,具体如下:
什么是HMAC-MD5?
1、比如你和对方共享了一个密钥K,现在你要发消息给对方,既要保证消息没有被篡改,又要能证明信息确实是你本人发的,那么就把原信息和使用K计算的HMAC的值一起发过去。对方接到之后,使用自己手中的K把消息计算一下HMAC,如果和你发送的HMAC一致,那么可以认为这个消息既没有被篡改也没有冒充。
2、MD5就是通过散列对要输出的数据进行摘要,接收到数据时,再同样进行MD5散列,与给定的MD5散列值比较,一致不一致就很清楚了。通常来说,传输的数据和MD5是不同的渠道给出的,比如网页上显示MD5,下载链接是某个镜像网站的。如果要通过同一个渠道发送数据和散列值的话(比如消息认证码),就要考虑数据和MD5同时被篡改的问题,如果第三方修改了数据,然后进行MD5散列,并一块发给接收方,接收方并不能察觉到数据被篡改。HMAC-MD5就可以用一把发送方和接收方都有的key进行计算,而没有这把key的第三方是无法计算出正确的散列值的,这样就可以防止数据被篡改。
python版:
#coding:utf-8
importsys
reload(sys)
sys.setdefaultencoding('utf-8')
importhmac
importhashlib
####################设置Key值##############
ekey='laidefa'
###############输入数据############
to_enc='{"name":"zhangsan"}'
enc_res=hmac.new(ekey,to_enc,hashlib.md5).hexdigest()
printenc_res
输出结果:
"D:\ProgramFiles\Python27\python.exe"D:/PycharmProjects/learn2017/hmacmd5.py
2cbb94ce78b35e4030851c4d40dacf12
Processfinishedwithexitcode0
java版:
packagetom;
importjava.security.MessageDigest;
importjavax.crypto.KeyGenerator;
importjavax.crypto.Mac;
importjavax.crypto.SecretKey;
importjavax.crypto.spec.SecretKeySpec;
/**
*基础加密组件
*@version1.0
*/
publicclassHmacmd5{
/**
*MAC算法可选以下多种算法
*
*
*HmacMD5
*HmacSHA1
*HmacSHA256
*HmacSHA384
*HmacSHA512
*
*/
publicstaticfinalStringKEY_MAC="HmacMD5";
/**
*HMAC加密
*
*@paramdata
*@paramkey
*@return
*@throwsException
*/
publicstaticbyte[]encryptHMAC(byte[]data,Stringkey)throwsException{
SecretKeysecretKey=newSecretKeySpec(key.getBytes(),KEY_MAC);
Macmac=Mac.getInstance(secretKey.getAlgorithm());
mac.init(secretKey);
returnmac.doFinal(data);
}
/*byte数组转换为HexString*/
publicstaticStringbyteArrayToHexString(byte[]b){
StringBuffersb=newStringBuffer(b.length*2);
for(inti=0;i
输出结果:
2cbb94ce78b35e4030851c4d40dacf12
PS:关于加密解密感兴趣的朋友还可以参考本站在线工具:
文字在线加密解密工具(包含AES、DES、RC4等):
http://tools.jb51.net/password/txt_encode
MD5在线加密工具:
http://tools.jb51.net/password/CreateMD5Password
在线散列/哈希算法加密工具:
http://tools.jb51.net/password/hash_encrypt
在线MD5/hash/SHA-1/SHA-2/SHA-256/SHA-512/SHA-3/RIPEMD-160加密工具: