簽名算法參考__OpenAPI使用手冊_雲監控-阿裏雲
以下是Java版簽名算法參考和C++版簽名算法參考
Java簽名算法參考
簽名代碼:UrlUtil.java
import java.net.URLEncoder;import java.util.Map;import org.apache.commons.lang.StringUtils;import org.apache.log4j.Logger;public class UrlUtil {private static Logger logger = Logger.getLogger(UrlUtil.class);private final static String CHARSET_UTF8 = "utf8";/**** @param url* @return*/public static String urlEncode(String url) {if (!StringUtils.isEmpty(url)) {try {url = URLEncoder.encode(url, "UTF-8");} catch (Exception e) {logger.warn("Url encode error:" + e.getMessage());}}return url;}public static String generateQueryString(Map<String, String> params, boolean isEncodeKV) {StringBuilder canonicalizedQueryString = new StringBuilder();for (Map.Entry<String, String> entry : params.entrySet()) {if (isEncodeKV)canonicalizedQueryString.append(percentEncode(entry.getKey())).append("=").append(percentEncode(entry.getValue())).append("&");elsecanonicalizedQueryString.append(entry.getKey()).append("=").append(entry.getValue()).append("&");}if (canonicalizedQueryString.length() > 1) {canonicalizedQueryString.setLength(canonicalizedQueryString.length() - 1);}return canonicalizedQueryString.toString();}public static String percentEncode(String value) {try {// 使用URLEncoder.encode編碼後,將"+","*","%7E"做替換即滿足 API規定的編碼規範return value == null ? null : URLEncoder.encode(value, CHARSET_UTF8).replace("+", "%20").replace("*", "%2A").replace("%7E", "~");} catch (Exception e) {//不可能發生的異常}return "";}}
SignatureUtils.java
import java.io.IOException;import java.io.UnsupportedEncodingException;import java.net.URI;import java.net.URISyntaxException;import java.net.URLDecoder;import java.net.URLEncoder;import java.util.Map;import java.util.TreeMap;import javax.crypto.Mac;import javax.crypto.spec.SecretKeySpec;import org.apache.commons.codec.binary.Base64;import org.apache.commons.lang.StringUtils;public class SignatureUtils {private final static String CHARSET_UTF8 = "utf8";private final static String ALGORITHM = "UTF-8";private final static String SEPARATOR = "&";public static Map<String, String> splitQueryString(String url)throws URISyntaxException, UnsupportedEncodingException {URI uri = new URI(url);String query = uri.getQuery();final String[] pairs = query.split("&");TreeMap<String, String> queryMap = new TreeMap<String, String>();for (String pair : pairs) {final int idx = pair.indexOf("=");final String key = idx > 0 ? pair.substring(0, idx) : pair;if (!queryMap.containsKey(key)) {queryMap.put(key, URLDecoder.decode(pair.substring(idx + 1), CHARSET_UTF8));}}return queryMap;}public static String generate(String method, Map<String, String> parameter,String accessKeySecret) throws Exception {String signString = generateSignString(method, parameter);System.out.println("signString---"+signString);byte[] signBytes = hmacSHA1Signature(accessKeySecret + "&", signString);String signature = newStringByBase64(signBytes);System.out.println("signature---"+signature);if ("POST".equals(method))return signature;return URLEncoder.encode(signature, "UTF-8");}public static String generateSignString(String httpMethod, Map<String, String> parameter)throws IOException {TreeMap<String, String> sortParameter = new TreeMap<String, String>();sortParameter.putAll(parameter);String canonicalizedQueryString = UrlUtil.generateQueryString(sortParameter, true);if (null == httpMethod) {throw new RuntimeException("httpMethod can not be empty");}StringBuilder stringToSign = new StringBuilder();stringToSign.append(httpMethod).append(SEPARATOR);stringToSign.append(percentEncode("/")).append(SEPARATOR);stringToSign.append(percentEncode(canonicalizedQueryString));return stringToSign.toString();}public static String percentEncode(String value) {try {return value == null ? null : URLEncoder.encode(value, CHARSET_UTF8).replace("+", "%20").replace("*", "%2A").replace("%7E", "~");} catch (Exception e) {}return "";}public static byte[] hmacSHA1Signature(String secret, String baseString)throws Exception {if (StringUtils.isEmpty(secret)) {throw new IOException("secret can not be empty");}if (StringUtils.isEmpty(baseString)) {return null;}Mac mac = Mac.getInstance("HmacSHA1");SecretKeySpec keySpec = new SecretKeySpec(secret.getBytes(CHARSET_UTF8), ALGORITHM);mac.init(keySpec);return mac.doFinal(baseString.getBytes(CHARSET_UTF8));}public static String newStringByBase64(byte[] bytes)throws UnsupportedEncodingException {if (bytes == null || bytes.length == 0) {return null;}return new String(Base64.encodeBase64(bytes, false), CHARSET_UTF8);}public static void main(String[] args) {String str = "GET&%2F&AccessKeyId%3DCdwKFNmXeHJuMOrT%26Action%3DDescribeInstances%26Format%3DJSON%26RegionId%3Dcn-hangzhou%26SignatureMethod%3DHMAC-SHA1%26SignatureNonce%3D9fdf20f2-9a32-4872-bcd4-c6036082ebef%26SignatureVersion%3D1.0%26Timestamp%3D2015-12-21T09%253A05%253A44Z%26Version%3D2014-05-26";byte[] signBytes;try {signBytes = SignatureUtils.hmacSHA1Signature("byczfpx4PKBzUNjjL4261cE3s6HQmH" + "&", str.toString());String signature = SignatureUtils.newStringByBase64(signBytes);} catch (Exception e) {// TODO Auto-generated catch blocke.printStackTrace();}}}
C++ 簽名算法參考
#include "ali_rpc_request.h"#include "ali_string_utils.h"#include "ali_encode_utils.h"#include "ali_urlencode.h"#include "ali_log.h"#include <stdio.h>#include <time.h>static std::string get_utc_string() {time_t now;struct tm *timenow;now = time(&now);timenow = gmtime(&now);std::string res= get_format_string("%d-%02d-%02dT%02d:%02d:%02dZ", timenow->tm_year + 1900,timenow->tm_mon + 1,timenow->tm_mday,timenow->tm_hour,timenow->tm_min,timenow->tm_sec);return res;}AliRpcRequest::AliRpcRequest(std::string version,std::string appid,std::string secret,std::string url): AliHttpRequest(url),version_(version),appid_(appid),secret_(secret),url_(url) {}std::string AliRpcRequest::GetSignUrl() {std::string encoded;std::map<std::string, std::string> mapWithPublicArgs;time_t now;time(&now);this->sign_nounce = get_format_string("%ld", now);this->utc_time_ = get_utc_string();if(this->query_.size()) {std::vector<std::string> vec_queries;strsplit(this->query_, vec_queries, "&");for(int i = 0; i < vec_queries.size(); i++) {std::string& item = vec_queries[i];int pos = item.find("=");mapWithPublicArgs[item.substr(0, pos)] = item.substr(pos + 1, item.size() - pos - 1);}}mapWithPublicArgs["Format"] = "JSON";mapWithPublicArgs["Version"] = this->version_;mapWithPublicArgs["AccessKeyId"] = this->appid_;mapWithPublicArgs["SignatureMethod"] = "HMAC-SHA1";mapWithPublicArgs["TimeStamp"] = utc_time_;mapWithPublicArgs["SignatureVersion"] = "1.0";mapWithPublicArgs["SignatureNonce"] = sign_nounce;//for(std::map<std::string, std::string>::iterator it = mapWithPublicArgs.begin();it != mapWithPublicArgs.end(); it++) {if(!encoded.empty()) {encoded.append("&");}append_format_string(encoded, "%s=%s", urlencode(it->first).c_str(), urlencode(it->second).c_str());}encoded = this->method_ + "&" + urlencode("/") + "&" + urlencode(encoded);ALI_LOG("sign str=%sn", encoded.c_str());return encoded;}int AliRpcRequest::CommitRequest() {std::string sign_url = GetSignUrl();std::string sign = encode_compute_hmac_sha1(this->secret_ + "&",(char*)sign_url.c_str(),sign_url.size());AddRequestQuery("TimeStamp", utc_time_);AddRequestQuery("Format", "JSON");AddRequestQuery("Version", this->version_);AddRequestQuery("AccessKeyId", this->appid_);AddRequestQuery("SignatureMethod", "HMAC-SHA1");AddRequestQuery("SignatureVersion", "1.0");AddRequestQuery("SignatureNonce", this->sign_nounce);AddRequestQuery("Signature", sign);return AliHttpRequest::CommitRequest();}
最後更新:2016-11-23 16:04:01
上一篇:
接口簡介__OpenAPI使用手冊_雲監控-阿裏雲
下一篇:
預設監控項參考__OpenAPI使用手冊_雲監控-阿裏雲
ALIYUN::ECS::InstanceGroup__資源列表_資源編排-阿裏雲
查詢模板信息__模板相關接口_API 文檔_資源編排-阿裏雲
產品發行版本說明__產品簡介_E-MapReduce-阿裏雲
阿裏雲大數據學院落戶青島西海岸新區!中國北方第一所!
子賬號訪問__授權管理_阿裏雲物聯網套件-阿裏雲
了解視頻點播流程__開發人員指南_視頻點播-阿裏雲
阿裏雲大數據平台服務協議__相關協議_平台介紹_數加平台介紹-阿裏雲
子用戶登錄常見問題__常見問題_產品使用問題_訪問控製-阿裏雲
原地擴容裸盤 (Linux)__擴容磁盤概覽_磁盤_用戶指南_雲服務器 ECS-阿裏雲
ZoneType__數據類型_API 參考_雲服務器 ECS-阿裏雲
相關內容
常見錯誤說明__附錄_大數據計算服務-阿裏雲
發送短信接口__API使用手冊_短信服務-阿裏雲
接口文檔__Android_安全組件教程_移動安全-阿裏雲
運營商錯誤碼(聯通)__常見問題_短信服務-阿裏雲
設置短信模板__使用手冊_短信服務-阿裏雲
OSS 權限問題及排查__常見錯誤及排除_最佳實踐_對象存儲 OSS-阿裏雲
消息通知__操作指南_批量計算-阿裏雲
設備端快速接入(MQTT)__快速開始_阿裏雲物聯網套件-阿裏雲
查詢API調用流量數據__API管理相關接口_API_API 網關-阿裏雲
使用STS訪問__JavaScript-SDK_SDK 參考_對象存儲 OSS-阿裏雲