本文摘自php中文网,作者不言,侵删。
这篇文章主要介绍了Python实现的HMacMD5加密算法,简单说明了HMAC-MD5加密算法的概念、原理并结合实例形式分析了Python实现HMAC-MD5加密算法的相关操作技巧,,末尾还附带了Java实现HMAC-MD5加密算法的示例,需要的朋友可以参考下本文实例讲述了Python实现的HMacMD5加密算法。分享给大家供大家参考,具体如下:
什么是 HMAC-MD5?
1、比如你和对方共享了一个密钥K,现在你要发消息给对方,既要保证消息没有被篡改,又要能证明信息确实是你本人发的,那么就把原信息和使用K计算的HMAC的值一起发过去。对方接到之后,使用自己手中的K把消息计算一下HMAC,如果和你发送的HMAC一致,那么可以认为这个消息既没有被篡改也没有冒充。
2、MD5就是通过散列对要输出的数据进行摘要,接收到数据时,再同样进行MD5散列,与给定的MD5散列值比较,一致不一致就很清楚了。通常来说,传输的数据和MD5是不同的渠道给出的,比如网页上显示MD5,下载链接是某个镜像网站的。如果要通过同一个渠道发送数据和散列值的话(比如消息认证码),就要考虑数据和MD5同时被篡改的问题,如果第三方修改了数据,然后进行MD5散列,并一块发给接收方,接收方并不能察觉到数据被篡改。HMAC-MD5就可以用一把发送方和接收方都有的key进行计算,而没有这把key的第三方是无法计算出正确的散列值的,这样就可以防止数据被篡改。
python 版:
1 2 3 4 5 6 7 8 9 10 11 12 | import sys
reload (sys)
sys.setdefaultencoding( 'utf-8' )
import hmac
import hashlib
ekey = 'laidefa'
to_enc = '{"name":"zhangsan"}'
enc_res = hmac.new(ekey, to_enc, hashlib.md5).hexdigest()
print enc_res
|
输出结果:
"D:\Program Files\Python27\python.exe" D:/PycharmProjects/learn2017/hmacmd5.py
2cbb94ce78b35e4030851c4d40dacf12
Process finished with exit code 0
java版:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 | package tom;
import java.security.MessageDigest;
import javax.crypto.KeyGenerator;
import javax.crypto.Mac;
import javax.crypto.SecretKey;
import javax.crypto.spec.SecretKeySpec;
/**
* 基础加密组件
* @version 1.0
*/
public class Hmacmd5 {
/**
* MAC算法可选以下多种算法
*
* <pre>
* HmacMD5
* HmacSHA1
* HmacSHA256
* HmacSHA384
* HmacSHA512
* </pre>
*/
public static final String KEY_MAC = "HmacMD5" ;
/**
* HMAC加密
*
* @param data
* @param key
* @return
* @throws Exception
*/
public static byte [] encryptHMAC( byte [] data, String key) throws Exception {
SecretKey secretKey = new SecretKeySpec(key.getBytes(), KEY_MAC);
Mac mac = Mac.getInstance(secretKey.getAlgorithm());
mac.init(secretKey);
return mac.doFinal(data);
}
public static String byteArrayToHexString( byte [] b) {
StringBuffer sb = new StringBuffer(b.length * 2 );
for ( int i = 0 ; i < b.length; i++) {
int v = b[i] & 0xff ;
if (v < 16 ) {
sb.append( '0' );
}
sb.append(Integer.toHexString(v));
}
return sb.toString();
}
public static void main(String[] args) throws Exception{
String inputStr = "{\"name\":\"zhangsan\"}" ;
byte [] inputData = inputStr.getBytes();
String key = "laidefa" ;
System.out.println(Hmacmd5.byteArrayToHexString(Hmacmd5.encryptHMAC(inputData, key)));
}
}
|
输出结果:
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加密工具:
http://tools.jb51.net/password/hash_md5_sha
在线sha1/sha224/sha256/sha384/sha512加密工具:
http://tools.jb51.net/password/sha_encode 相关推荐:
转:HmacMD5算法[php版]
以上就是Python实现的HMacMD5加密算法示例_python的详细内容,更多文章请关注木庄网络博客!!
相关阅读 >>
Python生成器与迭代器的区别
Python能做脚本吗
Python建议每行最多容纳多少字符
Python怎么安装词云wordcloud
学习Python需要注意的地方
Python采用什么开源协议
Python多线程的优点是什么?六大优点助你了解多线程
学Python需要英语基础吗
Python十进制小数和二进制小数相互转换的实现方式
Python的random怎么用
更多相关阅读请进入《Python》频道 >>
人民邮电出版社
python入门书籍,非常畅销,超高好评,python官方公认好书。
转载请注明出处:木庄网络博客 » Python实现的HMacMD5加密算法示例_python