
"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,并将其加入到消息中,然后传输尘老薯。接收方利用与发送方共享的密钥进行鉴别认证 等。
欢迎分享,转载请注明来源:内存溢出
微信扫一扫
支付宝扫一扫
评论列表(0条)