办公
互联网中间件
合作伙伴
智能管理
备份
大数据
1. Obs Endpoint类型
(1)路径类型endpoint
内网域名*.cloud.pub类型的endpoint被称为路径类型的endpoint。比如obs-cn-shanghai-internal.cloud.pub是路径类型的endpoint。对于该类型的endpoint,请求中bucket是放到request URI中的。
比如一个上传文件的请求:https://obs-cn-shanghai-internal.cloud.pub/mybucket/mykey
(2)五级域名类型endpoint
若endpoint为四级域名,且域名为公网域名,则此endpoint为五级域名类型的endpoint。比如endpoint obs-cn-shanghai.yun.pingan.com。此种请求需要在路径类型请求的基础上做修改:需要将bucket从request URI中剔除并移动到host的最前端,且将参数名为bucket的参数从请求中移除(如果有)。
比如,对于上传文件的请求https://obs-cn-shanghai.yun.pingan.com/mybucket/mykey,其五级域名风格:https://mybucket.obs-cn-shanghai.yun.pingan.com/mykey。
2. 签名生成规则
在Rest请求中,header Authorization生成规则如下:
StringToSign = HTTP-Verb + "\n" + Content-MD5 + "\n" + Content-Type + "\n" + Date + "\n" + userDefinedMetaHeaders + theRequestResource; Signature = Base64( HMAC-SHA1( secretKey, UTF-8 (StringToSign) ) ); Authorization = "AWS" + " " + AWSAccessKeyId + ":" + Signature; |
请求的动作,如括GET、PUT、DELETE等。
表示换行符,必须加
表示请求内容数据的MD5值,对消息内容(不包括头部)计算MD5值获得128比特位数字,对该数字进行base64编码而得到。该请求头可用于消息合法性的检查(消息内容是否与发送时一致)
如”eB5eJF1ptWaXm4bijSPyxw==”,也可以为空
表示请求内容的类型,如”application/octet-stream”,也可以为空
请求发起的GMT时间,如Fri, 14 Jul 2017 09:06:22 GMT
用户定义的metadata将被设置到请求的头部。比如,设置一个name为color值为blue的metadata,需要添加一个请求头x-amz-meta-color:blue。此时,userDefinedMetaHeaders为x-amz-meta-color:blue。若有多个自定义的header,则按header name的自然顺序排序。比如,有三个自定义的header分别为width,height,color,则被签名的片段应该像这样:
x-amz-meta-color:red x-amz-meta-height:10cm x-amz-meta-width:100cm |
为请求的URL的uri+[?子资源]+[关键的自然顺序排序的参数name=value]列表。
如请求为 http://{host}/{bucket}/{key}?partNumber=1&uploadId=abc
则theRequestResource为/{bucket}/{key}?partNumber=1&uploadId=abc