Python实现的HMacMD5加密算法示例_python


本文摘自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

#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版:

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);

  }

  /*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

相关推荐:

转:HmacMD5算法[php版]

以上就是Python实现的HMacMD5加密算法示例_python的详细内容,更多文章请关注木庄网络博客!!

相关阅读 >>

Python读取文本数据并转化为dataframe格式的方法详解

Python可以运行在jvm上吗

Python如何切换线程

Python有重载吗

input函数的用法是什么?

Python中的命名空间和范围

Python中socket之客户端与服务端握手的实例

Python中关于日期加减法的操作详解

vs可以写Python

Python如何求水仙花数?

更多相关阅读请进入《Python》频道 >>




打赏

取消

感谢您的支持,我会继续努力的!

扫码支持
扫码打赏,您说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

分享从这里开始,精彩与您同在

评论

管理员已关闭评论功能...