为保证API的安全调用,在调用API时,阿里云ENS会对每个API请求通过签名(Signature)进行身份验证。无论您使用HTTP还是HTTPS协议提交请求,都需要在请求中包含签名信息。

说明 阿里云ENS提供了多种编程语言的SDK及第三方SDK,可以省略计算签名步骤,下载SDK请前往阿里云SDK中心

RAM授权

为了确保您的账号安全,建议您使用RAM用户的身份凭证调用API。如果您使用RAM用户调用API,您需要为该RAM用户创建、附加相应的授权策略。ENS中可授权的资源和接口列表,请参见RAM资源授权,获取AccessKey,请参见获取AccessKey

API签名

ENS服务会对每个API请求进行身份验证,无论您使用HTTP还是HTTPS协议提交请求,都需要在请求中包含签名(Signature)信息。具体签名计算方法,请参见签名机制

ENS通过使用AccessKey ID和AccessKey Secret进行对称加密的方法来验证请求的发送者身份。AccessKey是为阿里云账号和RAM用户发布的一种身份凭证(类似于用户的登录密码),其中AccessKey ID用于标识访问者的身份,AccessKey Secret是用于加密签名字符串和服务器端验证签名字符串的密钥,必须严格保密。

StartInstance API为例,假设使用的AccessKey ID为yourAccessKey ID, AccessKey Secret为yourAccessKey Secret。 签名前的请求URL如下:

https://ens.aliyuncs.com/?Action=StartInstance
&InstanceId=testId
&Format=xml
&AccessKeyId=yourAccessKey ID
&SignatureMethod=HMAC-SHA1
&SignatureNonce=3ee8c1b8-83d3-44af-a94f-4e0ad82fd6cf
&Version=2017-11-10
&SignatureVersion=1.0

使用testsecret&,计算得到的签名值如下:

Y8c1u47r2gHn6scXqz92wklKws1=

将签名作为Signature参数加入到URL请求中,最后得到的URL如下:

https://ens.aliyuncs.com/?Action=StartInstance
&InstanceId=testId
&Format=xml
&AccessKeyId=yourAccessKey ID
&SignatureMethod=HMAC-SHA1
&SignatureNonce=3ee8c1b8-83d3-44af-a94f-4e0ad82fd6cf
&Version=2017-11-10
&SignatureVersion=1.0&Signature=Y8c1u47r2gHn6scXqz92wklKws1=

阿里云为您提供了多种编程语言SDK签名示例代码。