文档章节

Java签名算法之HMAC-SHA1

王爵nice
 王爵nice
发布于 2015/05/21 18:29
字数 336
阅读 1313
收藏 1


-

import java.security.SignatureException;

import javax.crypto.Mac;
import javax.crypto.spec.SecretKeySpec;

/**
 * This class defines common routines for generating authentication signatures
 * for AWS requests.
 */
public class Signature {
	private static final String HMAC_SHA1_ALGORITHM = "HmacSHA1";

	/**
	 * Computes RFC 2104-compliant HMAC signature. * @param data The data to be
	 * signed.
	 * 
	 * @param key
	 *            The signing key.
	 * @return The Base64-encoded RFC 2104-compliant HMAC signature.
	 * @throws java.security.SignatureException
	 *             when signature generation fails
	 */
	public static String calculateRFC2104HMAC(String data, String key)
			throws java.security.SignatureException {
		String result;
		try {

			// get an hmac_sha1 key from the raw key bytes
			SecretKeySpec signingKey = new SecretKeySpec(key.getBytes(),
					HMAC_SHA1_ALGORITHM);

			// get an hmac_sha1 Mac instance and initialize with the signing key
			Mac mac = Mac.getInstance(HMAC_SHA1_ALGORITHM);
			mac.init(signingKey);

			// compute the hmac on input data bytes
			byte[] rawHmac = mac.doFinal(data.getBytes());

			// base64-encode the hmac
			result = BASE64Encoder.encode(rawHmac);
//			result = Encoding.EncodeBase64(rawHmac);

		} catch (Exception e) {
			throw new SignatureException("Failed to generate HMAC : "
					+ e.getMessage());
		}
		return result;
	}
	
	public static byte[] hmacSHA1(String data, String key) throws java.security.SignatureException {
		try {
			// get an hmac_sha1 key from the raw key bytes
			SecretKeySpec signingKey = new SecretKeySpec(key.getBytes(),
					HMAC_SHA1_ALGORITHM);

			// get an hmac_sha1 Mac instance and initialize with the signing key
			Mac mac = Mac.getInstance(HMAC_SHA1_ALGORITHM);
			mac.init(signingKey);

			// compute the hmac on input data bytes
			byte[] rawHmac = mac.doFinal(data.getBytes());

			return rawHmac;

		} catch (Exception e) {
			throw new SignatureException("Failed to generate HMAC : "
					+ e.getMessage());
		}
	}
}

import java.security.InvalidKeyException;
import java.security.NoSuchAlgorithmException;
import java.security.SignatureException;
import java.util.Formatter; 
import javax.crypto.Mac;
import javax.crypto.spec.SecretKeySpec;  
/** 
 * The <tt>HmacSha1Signature</tt> shows how to calculate  
 * a message authentication code using HMAC-SHA1 algorithm. 
 * 
 * <pre> 
 * % java -version 
 * java version "1.6.0_11" 
 * % javac HmacSha1Signature.java  
 * % java -ea HmacSha1Signature 
 * 104152c5bfdca07bc633eebd46199f0255c9f49d 
 * </pre> 
 * 
 */
 public class HmacSha1Signature {	
     private static final String HMAC_SHA1_ALGORITHM = "HmacSHA1"; 	
     private static String toHexString(byte[] bytes) {		
         Formatter formatter = new Formatter();				
         for (byte b : bytes) {			
             formatter.format("%02x", b);		、
         } 		
         return formatter.toString();	
    } 	
    
    public static String calculateRFC2104HMAC(String data, String key) throws SignatureException, NoSuchAlgorithmException, InvalidKeyException	{		
        SecretKeySpec signingKey = new SecretKeySpec(key.getBytes(), HMAC_SHA1_ALGORITHM);		Mac mac = Mac.getInstance(HMAC_SHA1_ALGORITHM);		
        mac.init(signingKey);		
        return toHexString(mac.doFinal(data.getBytes()));	
     } 	
     
     public static void main(String[] args) throws Exception {		
         String hmac = calculateRFC2104HMAC("data", "key"); 		
         System.out.println(hmac);		
         assert hmac.equals("104152c5bfdca07bc633eebd46199f0255c9f49d");	
     }
}

-

© 著作权归作者所有

王爵nice

王爵nice

粉丝 290
博文 72
码字总数 72355
作品 5
浦东
程序员
私信 提问
php的hash_hmac

本人是学java的,而接口要求用php得值key=base64_encode(hash_hmac('sha1',$public_key,$private_key,TRUE));百度了好久,没找到对应的java方法,有哪位朋友知道吗?劳烦告知 万分感谢...

醒醒盹
2014/07/28
3.5K
2
【HAVENT原创】前端使用 jsrsasign 进行 RSA 加密、解密、签名、验签

最近因项目需求,需要配合 JAVA 后端返回的签名,在 H5 网页中做验签功能。网上搜了一下发现了 jsrsasign 满足需求,所以顺便研究了一下 jsrsasign 。 首先去官网下载压缩包,解压后只需要引...

HAVENT
05/24
76
0
rds 签名机制实例及补充说明

实为吾之愚见,望诸君酌之!闻过则喜,与君共勉 本篇主要是做下rds签名机制的补充,以简单的代码实例来解释下每个步骤的含义,尽量会按照官方文档的描述举例,关于签名机制的官方文档在这里: ...

手辨
2018/09/20
0
0
Android Studio 中 获得 开发版和发布版 SHA1

概述 因为在百度开发者平台创建应用的时候,需要发布版和开发版SHA1,所以才急着学了以下。不难,只需要在Android Studio 的 Terminal里面输入相应的命令就行。 获得开发版 SHA1 获得开发版S...

聪聪小可爱
2016/10/14
25
0
Message Authentication Code_消息认证码算法

Message Authentication Code_消息认证码算法 内容来源于网络 部分内容摘自博客:http://blog.csdn.net/zzminer/article/details/8574287 MAC算法结合了MD5和SHA算法的优势,并加入密钥的支持...

秋风醉了
2014/07/14
5.4K
1

没有更多内容

加载失败,请刷新页面

加载更多

全面兼容IE6/IE7/IE8/FF的CSS HACK写法

浏览器市场的混乱,给设计师造成很大的麻烦,设计的页面兼容完这个浏览器还得兼容那个浏览器,本来ie6跟ff之间的兼容是很容易解决的。加上个ie7会麻烦点,ie8的出现就更头疼了,原来hack ie...

前端老手
8分钟前
3
0
常用快递电子面单批量打印api接口对接demo-JAVA示例

目前有三种方式对接电子面单: 1.快递公司:各家快递公司逐一对接接口 2.菜鸟:支持常用15家快递电子面单打印 3.快递鸟:仅对接一次,支持常用30多家主流快递电子面单打印 目前也是支持批量打...

程序的小猿
11分钟前
5
0
Yii 框架中rule规则必须搭配验证函数才能使用

public $store_id;public $user_id;public $page;public $limit;public $list;public $mch_list;public $cart_id;public $is_community;public $shop_id;public $cart_typ......

chenhongjiang
13分钟前
2
0
Flutter使用Rammus实现阿里云推送

前言: 最近新的Flutter项目有“阿里云推送通知”的需求,就是Flutter的App启动后检测到有新的通知,点击通知栏然后跳转到指定的页面。在这里我使用的是第三方插件Rammus来实现通知的推送,之...

EmilyWu
13分钟前
38
0
Knative 实战:三步走!基于 Knative Serverless 技术实现一个短网址服务

短网址顾名思义就是使用比较短的网址代替很长的网址。维基百科上面的解释是这样的: 短网址又称网址缩短、缩短网址、URL 缩短等,指的是一种互联网上的技术与服务,此服务可以提供一个非常短...

阿里巴巴云原生
28分钟前
2
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部