Java实现HMacMD5加密,用于淘宝客JS 组件 API 调用时生成 sign 的签名

原文:Java实现HMacMD5加密,用于淘宝客JS 组件 API 调用时生成 sign 的签名

源代码下载地址:http://www.zuidaima.com/share/1550463397874688.htm

HMacMD5 加密纯 Java 实现,用于淘宝客 JS 组件 API 调用时生成 sign 的签名

另外:给大家贴一段淘宝客组件 API (JS API) 调用时,生成签名的核心代码。 另外:从事淘宝客开发的童鞋,碰到啥问题可以找我交流!!!

String timestamp = System.currentTimeMillis() + "";

String message = TaobaokeConfig.APP_SECRET + "app_key" + TaobaokeConfig.APP_KEY + "timestamp" + timestamp + TaobaokeConfig.APP_SECRET;

byte[] bytes = HMacMD5.getHmacMd5Bytes(TaobaokeConfig.APP_SECRET.getBytes(), message.getBytes());
String mysign = Hex.byte2HexStr(bytes).toLowerCase();

WebUtil.addCookie(response, "timestamp", timestamp, 120);

WebUtil.addCookie(response, "sign", mysign, 120); 

HMacMD5.java

/*
 *    Copyright 2012-2013 The Haohui Network Corporation
 */
package com.zuidaima.haohui.common.utils;

import java.io.UnsupportedEncodingException;
import java.security.MessageDigest;
import java.security.NoSuchAlgorithmException;

/**
 * <pre>
 * HeX 之后 46 位
 * hmac
  HMAC的原理和应用
  hmac的原理
  计算HMAC需要一个散列函数hash(可以是md5或者sha-1)和一个密钥key。用L表示hash函数输出字符串长(md5是16),用B表示数据块的长度(md5和sha-1的分割数据块长都是64)。密钥key的长度可以小于等于数据块长B,如果大于数据块长度,可以使用hash函数对key进行转换,结果就是一个L长的key。
  然后创建两个B长的不同字符串:
  innerpad = 长度为B的 0×36
  outterpad = 长度为B的 0×5C
  计算输入字符串str的HMAC:
  hash(key ^ outterpad, hash(key ^ innerpad, str))
  hmac的应用
  hmac主要应用在身份验证中,它的使用方法是这样的:
  1. 客户端发出登录请求(假设是浏览器的GET请求)
  2. 服务器返回一个随机值,并在会话中记录这个随机值
  3. 客户端将该随机值作为密钥,用户密码进行hmac运算,然后提交给服务器
  4. 服务器读取用户数据库中的用户密码和步骤2中发送的随机值做与客户端一样的hmac运算,然后与用户发送的结果比较,如果结果一致则验证用户合法
  在这个过程中,可能遭到安全攻击的是服务器发送的随机值和用户发送的hmac结果,而对于截获了这两个值的黑客而言这两个值是没有意义的,绝无获取用户密码的可能性,随机值的引入使hmac只在当前会话中有效,大大增强了安全性和实用性。大多数的语言都实现了hmac算法,比如php的mhash、python的hmac.py、java的MessageDigest类,在web验证中使用hmac也是可行的,用js进行md5运算的速度也是比较快的。
 * </pre>
 *
 * @project baidamei
 * @author cevencheng <[email protected]> www.zuidaima.com
 * @create 2012-11-14 下午5:38:38
 */
public class HMacMD5 {
	/**
	 * 计算参数的md5信息
	 *
	 * @param str
	 *            待处理的字节数组
	 * @return md5摘要信息
	 * @throws NoSuchAlgorithmException
	 */
	private static byte[] md5(byte[] str) throws NoSuchAlgorithmException {
		MessageDigest md = MessageDigest.getInstance("MD5");
		md.update(str);
		return md.digest();
	}

	/**
	 * 将待加密数据data,通过密钥key,使用hmac-md5算法进行加密,然后返回加密结果。 参照rfc2104 HMAC算法介绍实现。
	 *
	 * @author 尹星 www.zuidaima.com
	 * @param key
	 *            密钥
	 * @param data
	 *            待加密数据
	 * @return 加密结果
	 * @throws NoSuchAlgorithmException
	 */
	public static byte[] getHmacMd5Bytes(byte[] key, byte[] data) throws NoSuchAlgorithmException {
		/*
		 * HmacMd5 calculation formula: H(K XOR opad, H(K XOR ipad, text))
		 * HmacMd5 计算公式:H(K XOR opad, H(K XOR ipad, text))
		 * H代表hash算法,本类中使用MD5算法,K代表密钥,text代表要加密的数据 ipad为0x36,opad为0x5C。
		 */
		int length = 64;
		byte[] ipad = new byte[length];
		byte[] opad = new byte[length];
		for (int i = 0; i < 64; i++) {
			ipad[i] = 0x36;
			opad[i] = 0x5C;
		}
		byte[] actualKey = key; // Actual key.
		byte[] keyArr = new byte[length]; // Key bytes of 64 bytes length
		/*
		 * If key's length is longer than 64,then use hash to digest it and use
		 * the result as actual key. 如果密钥长度,大于64字节,就使用哈希算法,计算其摘要,作为真正的密钥。
		 */
		if (key.length > length) {
			actualKey = md5(key);
		}
		for (int i = 0; i < actualKey.length; i++) {
			keyArr[i] = actualKey[i];
		}

		/*
		 * append zeros to K 如果密钥长度不足64字节,就使用0x00补齐到64字节。
		 */
		if (actualKey.length < length) {
			for (int i = actualKey.length; i < keyArr.length; i++)
				keyArr[i] = 0x00;
		}

		/*
		 * calc K XOR ipad 使用密钥和ipad进行异或运算。
		 */
		byte[] kIpadXorResult = new byte[length];
		for (int i = 0; i < length; i++) {
			kIpadXorResult[i] = (byte) (keyArr[i] ^ ipad[i]);
		}

		/*
		 * append "text" to the end of "K XOR ipad" 将待加密数据追加到K XOR ipad计算结果后面。
		 */
		byte[] firstAppendResult = new byte[kIpadXorResult.length + data.length];
		for (int i = 0; i < kIpadXorResult.length; i++) {
			firstAppendResult[i] = kIpadXorResult[i];
		}
		for (int i = 0; i < data.length; i++) {
			firstAppendResult[i + keyArr.length] = data[i];
		}

		/*
		 * calc H(K XOR ipad, text) 使用哈希算法计算上面结果的摘要。
		 */
		byte[] firstHashResult = md5(firstAppendResult);

		/*
		 * calc K XOR opad 使用密钥和opad进行异或运算。
		 */
		byte[] kOpadXorResult = new byte[length];
		for (int i = 0; i < length; i++) {
			kOpadXorResult[i] = (byte) (keyArr[i] ^ opad[i]);
		}

		/*
		 * append "H(K XOR ipad, text)" to the end of "K XOR opad" 将H(K XOR
		 * ipad, text)结果追加到K XOR opad结果后面
		 */
		byte[] secondAppendResult = new byte[kOpadXorResult.length + firstHashResult.length];
		for (int i = 0; i < kOpadXorResult.length; i++) {
			secondAppendResult[i] = kOpadXorResult[i];
		}
		for (int i = 0; i < firstHashResult.length; i++) {
			secondAppendResult[i + keyArr.length] = firstHashResult[i];
		}

		/*
		 * H(K XOR opad, H(K XOR ipad, text)) 对上面的数据进行哈希运算。
		 */
		byte[] hmacMd5Bytes = md5(secondAppendResult);

		return hmacMd5Bytes;

	}

	public static void main(String[] args) throws NoSuchAlgorithmException, UnsupportedEncodingException {
		byte[] macmd5 = HMacMD5.getHmacMd5Bytes("7e62ff29f6548e2e7cf5307315fb2b1".getBytes(), "".getBytes());
		System.out.println(Hex.byte2HexStr(macmd5));
		System.out.println(Hex.byte2HexStr("xxoo".getBytes()));
		System.out.println(Hex.byte2HexStr(HMacMD5.getHmacMd5Bytes("7e62ff29f6548e2e7cf5307315fb2b1".getBytes(), "xxoo".getBytes())));
	}
}
时间: 2024-10-16 21:35:27

Java实现HMacMD5加密,用于淘宝客JS 组件 API 调用时生成 sign 的签名的相关文章

使用 Python 全栈打造淘宝客微信机器人(上)

本篇  将会涉及: Python 环境下淘宝客 API 的使用: 使用 Python 第三方模块 itchat 实现微信的登录的自动回复操作: PyQt5 的布局管理与多线程应用 1 .前言 1.1.什么是淘宝客 相信很多人都听过或者接触过各类导购 APP.QQ 群.微信群分享一些淘宝商品的优惠券或是其他的优惠信息. 用户可以在这些渠道上获取到相较于从淘宝平台搜索出来的商品更加优惠的价格或者是领取到面额较大的优惠券. 这些渠道,都是属于淘宝客的渠道.淘宝客是淘宝平台推出的一种按成交计费的推广模式

手机淘宝客应用(服务端+客户端+数据库)源码项目

欢迎大家光临我的个人网店:http://shop.662p.com/shop/view8.html 这是一款比较完整的应用源码,手机淘宝客应用(服务端+客户端+数据库),客户端是Java代码实现编程,另外服务端是采用了php的常见框架实现的,代码里面有一个sql文件是数据库导入文件 ,里面的apk是用来升级的版本 设置. 文件大小:10.94 MB 服务器:thinkphp 代码里面有一个sql文件是数据库导入文件 ,里面的apk是用来升级的版本 设置update.xml 用来跟之前安装的对比版

轩宇淘宝客系统源码

轩宇淘宝客是一款适用于淘宝客打折单品推广的程序,无论老手或新手都能短时间内赚取大量佣金的淘宝客网站程序,不同于现在广泛的淘宝客推广网站.本程序可手动添加商品,同时也配置强大的多功能采集插件,可采集评论,也可自定义采集规则,全自动无人值守采集更新网站,无需人工维护.默认提供精美的页面设计模版,超好的用户访问体验,超高转化率.对搜索引擎收录友好,整站伪静态技术,访问速度快,无需等待漫长的生成HTML页面时间.后台傻瓜式操作,智能简单,2014年最新推荐淘宝客站长使用的单品推广程序. 前台打折促销风格

淘宝客知道这几个ID,收入将会提高50%

基础问题天天说,天天有人问.这篇文章写点基础的.特别对新手的帮助会很大哦. 1,PID,做淘宝客不知道PID,赚到钱也会被冻结. 如何手动获取PID 2,单品ID,淘宝商品的唯一识别编号,和身份证一样,每个商品都有个唯一的编号 天猫的 https://detail.tmall.com/item.htm?id=520105375809&ali_refid=a3_430583_1006:1103424533:N:%E4%B8%93%E4%B8%9A%E6%B3%B3%E8%A1%A3%E5%A5%B

.net淘宝客基础api 分页查询

1 using System; 2 using System.Collections.Generic; 3 using System.Configuration; 4 using System.Linq; 5 using System.Web; 6 using Top.Api; 7 using Top.Api.Request; 8 using Top.Api.Response; 9 10 namespace MvcWebApp.DataBase 11 { 12 public class TaoD

我刚刚建立个淘宝客网站,主要销售丰胸产品减肥药

我刚刚建立个淘宝客网站,主要销售丰胸产品减肥药,www.yazimeirongmeiti.com欢迎大家赏光!

腾讯从社群端整治淘宝客,90%的淘客群被封

近日不断有淘宝客反映,自己的社交账号被冻结,原因如下:该微信账号被用户投诉,并确认有大量发布垃圾信息等骚扰行为,被临时限制登录. 除此以外大量的淘客群也被封禁. 之前5月份淘宝客官方公众号发布了一条通知: "目前接到用户反馈:在微信/QQ等渠道的正常推广链接遭遇屏蔽,无法打开.如您碰到类似情况,建议可以在微信/QQ等网页上申诉.另外,分享出去的推广内容,先把链接去掉,引导买家通过淘口令购买!" 阿里随后也疑似反击:寄出快递中抽检小卡片,禁止卖家引导买家添加微信号.一旦被查出有可能删宝贝

查询类网站或成站长淘宝客新金矿

流量是玩转互联网的基础,传说的中的大牛一般都是倒腾流量的高手.在大牛眼中抓取流量是一门艺术,背后玩的是五花八门的思路. 这篇文章斗胆跟大家分享一个好玩的思路.文章将以剥洋葱的方式展开,希望剥完这颗洋葱会让你有相见恨晚之感. 在切入正题之前,先分析一下搜索需求这个概念.人们借助搜索引擎大抵有以下几个诉求:第一,了解是什么,寻找是什么类别的信息,这一块占据搜索流量的绝大部分.第二,想知道为什么,很多时候会用提问关键词去索引,譬如"怎么获取流量".第三类,单纯地想去某个网站,敲入关键词通过搜

2016年商家如何借势淘宝客打造淘宝爆款

如何利用好淘宝客?我们从商家如何借势淘宝客,获取更多流量.销量.潜在用户.如何通过淘宝客打造爆款,打造了爆款后面如何维护等等问题. 一.首先,我们在学会打造淘宝爆款之前,要先掌握流量.销量.转单.潜在客户等这几个问题. 1.流量 流量从哪里来?流量肯定不是从天上掉下来的,流量=用户.他们都是淘宝客们一个一个邀请过来,一个一个维护起来的.每一个 用户都来之不易,所以对于淘客来说,最痛恨的就是商家做伤害用户的事,譬如把用户拉到自己的CRM群啊,或者是产品品质方面有问题,或者是商家服务态度差 等等诸多