火山引擎对于每一次的 HTTPS 协议访问请求,会通过访问签名信息中的访问密钥(包括 Access Key ID 和 Secret Access Key),验证访问请求者身份。
账户和有权限的用户可以新建访问密钥,操作如下:
说明
CanonicalRequest = HTTPRequestMethod + '\n' + CanonicalURI + '\n' + CanonicalQueryString + '\n' + CanonicalHeaders + '\n' + SignedHeaders + '\n' + HexEncode(Hash(RequestPayload))
在签名之前,要将请求正规化,使得签名计算过程无异议,其主要过程及伪代码如下:
字段 | 说明 |
---|---|
HTTPRequestMethod | HTTP 请求方法,例如 POST。 |
CanonicalURI | 正规化后的 URI。如果 URI 为空,那么使用/ 作为绝对路径。 |
CanonicalQueryString | 正规化后的 QueryString。QueryString 正规化流程如下:
|
CanonicalHeaders | 正规化后的Header。其中伪代码如下:
其中, 注意
|
SignedHeaders | 参与签名的 Header 名称。
|
RequestPayload | 完整的请求的 Body。
|
签名字符串主要包含请求以及正规化请求的元数据信息,由签名算法、请求日期、信任状和正规化请求哈希值连接组成,伪代码如下:
StringToSign = Algorithm + '\n' + RequestDate + '\n' + CredentialScope + '\n' + HexEncode(Hash(CanonicalRequest))
字段说明如下。
字段 | 说明 |
---|---|
Algorithm | 签名的算法。目前火山引擎仅支持 HMAC-SHA256 签名算法。 |
RequestDate | 请求 UTC 时间。请使用YYYYMMDD'T'HHMMSS'Z' 格式,例如:20201103T104027Z 。 |
CredentialScope | 凭证范围。格式为YYYYMMDD/region/service/request 。 |
CanonicalRequest | 前序正规化请求的结果。 |
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))
说明
表达式中用{}
内的内容,代表上文计算出的中间过程。
Authorization: HMAC-SHA256 Credential={AccessKeyId}/{CredentialScope}, SignedHeaders={SignedHeaders}, Signature={Signature}