Python实现的HMacMD5加密算法示例

作者:开心果汁 时间:2022-01-15 06:05:31 

本文实例讲述了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
import sys
reload(sys)
sys.setdefaultencoding('utf-8')
import hmac
import hashlib
####################设置Key值##############
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版:


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);
 }
 /*byte数组转换为HexString*/
 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

希望本文所述对大家Python程序设计有所帮助。

来源:https://blog.csdn.net/u013421629/article/details/78355711

标签:Python,加密算法
0
投稿

猜你喜欢

  • 在Django中Pyecharts生成图表实现

    2023-07-27 08:16:32
  • ASP万用分页程序

    2007-09-21 12:45:00
  • php中获取指定IP的物理地址的代码(正则表达式)

    2023-11-23 07:04:36
  • python的​PyPDF2实现pdf文件切割和合并

    2023-02-07 19:57:39
  • 编辑BLOG文章的一些好习惯

    2007-11-15 06:35:00
  • Python中plt.imshow(image)无法显示图片的解决

    2022-01-12 15:33:04
  • PHP实现逐行删除文件右侧空格的方法 <font color=red>原创</font>

    2023-11-22 05:11:25
  • ASP实现SQL语句日期格式的加减运算

    2008-11-07 15:13:00
  • python关于多值参数的实例详解

    2023-11-05 21:43:35
  • [奇招] JS暴虐查找算法

    2008-07-06 21:17:00
  • Python中的Cookie模块如何使用

    2023-04-12 15:54:46
  • python排序算法之选择排序

    2023-03-15 11:56:56
  • CTF中的PHP特性函数解析之中篇

    2023-06-11 12:56:20
  • Python中多个数组行合并及列合并的方法总结

    2021-10-08 11:00:23
  • MySQL安全大讲堂:MySQL数据库安全配置

    2009-10-18 11:24:00
  • 基于Python编写一个简单的垃圾邮件分类器

    2022-02-26 08:11:23
  • python实现QQ邮箱/163邮箱的邮件发送

    2022-12-12 14:07:15
  • python两个list[]相加的实现方法

    2023-09-22 13:34:52
  • Swoole webSocket消息服务系统方案设计详解

    2023-06-12 16:16:32
  • windows环境下tensorflow安装过程详解

    2021-12-10 15:59:34
  • asp之家 网络编程 m.aspxhome.com