如何生成HMAC在Java中相当于一个Python的例子吗

如何生成HMAC在Java中相当于一个Python的例子吗,第1张

1. HMACSHA1似乎是你所需要的算法:SecretKeySpec keySpec = new SecretKeySpec(

"qnscAdgRlkIhAUPY44oiexBKtQbGY0orf7OV1I50".getBytes(),

"HmacSHA1")

Mac mac = Mac.getInstance("HmacSHA1")

mac.init(keySpec)

byte[] result = mac.doFinal("foo".getBytes())

BASE64Encoder encoder = new BASE64Encoder()

System.out.println(encoder.encode(result))

生产:+3h2gpjf4xcynjCGU5lbdMBwGOc=

请注意,我sun.misc.BASE64Encoder为迅速在这里,但你应该不依赖于太阳的JRE。以base64编码器在下议院编祥悄解码器将是一个更好的选择,例如。

2. A小调的事情,但如果你正在寻找一个相当于HMAC(那么默认的Python库的MD5算法,所以你需要的HMACMD5算法在Java中。 这个我有这个确切的问题,并认为此答案这是有帮助的 CodeGo.net,但我错过了一个地方传谨伏渣递到HMAC()的一部分,并就下一个兔子洞。希望这个答案可以防止其他人做的未来。 例如在Python REPL>>>import hmac

>>>hmac.new("keyValueGoesHere", "secretMessageToHash").hexdigest()

'1a7bb3687962c9e26b2d4c2b833b2bf2'

这等效于import org.apache.commons.codec.binary.Hex

import javax.crypto.Mac

import javax.crypto.spec.SecretKeySpec

public class HashingUtility {

public static String HMAC_MD5_encode(String key, String message) throws Exception {

SecretKeySpec keySpec = new SecretKeySpec(

key.getBytes(),

"HmacMD5")

Mac mac = Mac.getInstance("HmacMD5")

mac.init(keySpec)

byte[] rawHmac = mac.doFinal(message.getBytes())

return Hex.encodeHexString(rawHmac)

}

}

请注意,在我的例子我在干厅银什么。hexdigest相当于()

以下代码为JAVABEAN,加密用

[PHP]

package test

/*

* Copyright 1997-2001 by Sun Microsystems, Inc.,

* 901 San Antonio Road, Palo Alto, California, 94303, U.S.A.

* All rights reserved.

*

* This software is the confidential and proprietary information

* of Sun Microsystems, Inc. ("Confidential Information". You

* shall not disclose such Confidential Information and shall use

* it only in accordance with the terms of the license agreement

* you entered into with Sun.

*/

import java.security.*

import javax.crypto.*

/*

* This program demonstrates how to generate a secret-key object for

* HMAC-SHA1, and initialize an HMAC-SHA1 object with it.

*/

public class initMac {

public initMac() {

}

//定义加密算法带尘

String Algorithm = "HmacSHA1"

public byte[] HmacSHA1(String post) throws Exception {

// Generate secret key for HMAC-SHA1

KeyGenerator kg = KeyGenerator.getInstance(Algorithm)

SecretKey sk = kg.generateKey()

// Get instance of Mac object implementing HMAC-SHA1, and

// initialize it with the above secret key

Mac mac = Mac.getInstance(Algorithm)

mac.init(sk)

byte[] result = mac.doFinal(post.getBytes())

return result

}

}

[/PHP]

以下代码为调用上面JAVABEAN的部分

[PHP]package test

import test.initMac

/**

* <p>Title: </p>

*

* <p>Description: </租没p>蠢型禅

Java基本的单向加密算法:

1.BASE64 严格地说,属于编码格式,而非加密算法

2.MD5(Message Digest algorithm 5,信息摘要算法)

3.SHA(Secure Hash Algorithm,安全散列算法)

4.HMAC(Hash Message Authentication Code,散列消息鉴别码)

按 照RFC2045的定义,Base64被定义为:Base64内容传送编码被设计用来把任意序列的8位字节描述为一种不易被人直接识别的形式。(The Base64 Content-Transfer-Encoding is designed to represent arbitrary sequences of octets in a form that need not be humanly readable.)

常见于邮件、http加密,截取http信息,你就会发现登录 *** 作的用户名、密码字段通过BASE64加密的。

主要就是BASE64Encoder、BASE64Decoder两个类,我们只需要知道使用对应的方法即可。另,BASE加密后产生的字节位数是8的倍数,如果不够位数以=符号填充。

MD5

MD5 -- message-digest algorithm 5 (信息-摘要算法)缩写,广泛派者用于加密和解密技术,常用于文件校验。校验?不管文件多大,经过MD5后都能生成唯一的MD5值。好比现在的ISO校验,都 是MD5校验。怎么用?当然是把ISO经过MD5后产生MD5的值。一般下载linux-ISO的朋友都见过下载链接旁边放着MD5的串。就是用来验证文 件是否一致的。

HMAC

HMAC(Hash Message Authentication Code,散列消息鉴别码,基于密钥的Hash算法的认证协议。消息鉴别码实现鉴别的原理是,用公开函数和密钥产生一个固定长度的值作为认证标识,用这个 标识鉴别消息的完整含贺性。使用一个密钥生成一个固定大小的小数据块,即MAC,并将其加入到消息中,然后传输尘老薯。接收方利用与发送方共享的密钥进行鉴别认证 等。


欢迎分享,转载请注明来源:内存溢出

原文地址:https://54852.com/tougao/8223057.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2023-04-14
下一篇2023-04-14

发表评论

登录后才能评论

评论列表(0条)

    保存