云数据库 MySQL 版服务会对每个访问的请求进行身份验证,因此您需要在请求中包含签名信息。本文介绍云数据库 MySQL 版的 API 签名机制。
说明
您在访问需要按照下面的方法对请求进行签名处理:
CanonicalRequest = HTTPRequestMethod + '\n' + CanonicalURI + '\n' + CanonicalQueryString + '\n' + CanonicalHeaders + '\n' + SignedHeaders + '\n' + HexEncode(Hash(RequestPayload))
HTTPRequestMethod
指代 HTTP 请求的 method,例如:GET 、 POST 等。
CanonicalURI:
指代正规化后的 URI。如果 URI 为空,那么使用(/)作为绝对路径。在火山引擎中绝大多数接口的 URI 都为(/)。
CanonicalQueryString
指代正规化后的 Query String。例如:
CanonicalQueryString = "Action=ListUsers&Version=2018-01-01"
对于 Query String 的正规化大致的过程如下:
CanonicalHeaders
指代正规化后的 Header 。其中伪代码如下:
CanonicalHeaders = CanonicalHeadersEntry0 + CanonicalHeadersEntry1 + ... + CanonicalHeadersEntryN
其中
CanonicalHeadersEntry = Lowercase(HeaderName) + ':' + Trimall(HeaderValue) + '\n'
说明
\n
。SignedHeaders
指代参与签名的 Header 名称。签名 Header 是包含在正规化 Headers 中名称列表,其目的是指明哪些 Header 参与签名计算,从而忽略请求被 proxy 添加的额外 Header ,其中 host、x-date 两个 Header 如果存在则必须添加进来,伪代码如下:
SignedHeaders = Lowercase(HeaderName0) + ';' + Lowercase(HeaderName1) + ";" + ... + Lowercase(HeaderNameN)
RequestPayload
指代完整的请求的 body 。需要注意如下几点:
签名字符串主要包含请求以及正规化请求的元数据信息,由签名算法、请求日期、信任状和正规化请求哈希值连接组成,伪代码如下:
StringToSign = Algorithm + '\n' + RequestDate + '\n' + CredentialScope + '\n' + HexEncode(Hash(CanonicalRequest))
Algorithm
指代签名的算法,目前火山引擎仅支持 HMAC-SHA256 的签名算法。
RequestDate
指代请求 UTC 时间,请使用如下格式: YYYYMMDD'T'HHMMSS'Z'。
CredentialScope
指代信任状,格式为: YYYYMMDD/region/ service/request。
CanonicalRequest
指代上一小节正规化请求的结果。
在计算签名前,首先从私有访问密钥(secret AccessKey)派生出签名密钥(signing key),而不是直接使用私有访问密钥。具体计算过程如下:
kSecret = *Your Secret Access Key* kDate = HMAC(kSecret, Date) kRegion = HMAC(kDate, Region) kService = HMAC(kRegion, Service) kSigning = HMAC(kService, "request")
计算签名
Signature = HexEncode(HMAC(kSigning, StringToSign))
构建 Header
Authorization: HMAC-SHA256 Credential={AccessKeyId}/{CredentialScope}, SignedHeaders={SignedHeaders}, Signature={Signature}
说明
表达式中用{}括起来的代表上文计算出的中间过程。
更多详情,请参见签名示例。