吾爱破解 - 52pojie.cn

 找回密码
 注册[Register]

QQ登录

只需一步,快速开始

查看: 1627|回复: 3
收起左侧

[求助] TX云Authorization签名算法,更详细的说明,请求改写JS

[复制链接]
随拾 发表于 2020-5-14 09:58
之前发过一个帖子,资料可能不全,这次找到了更完整的说明文档,甚至于还有在线测试: https://cos5.cloud.tencent.com/static/cos-sign/
在构造签名前,必须先获取TX云账号的 API 密钥对,其中包含 SecretID 和 SecretKey 这两个参数已经可以获取,但是还不会这个签名的算法,请求朋友帮忙写个JS生成下
我已经写了易语言获取 SecretID 和 SecretKey的框架:https://lanzouj.com/iciyl9e
抓包数据也在这里,Fiddler抓包数据:https://lanzouj.com/icf0ckj
详细步骤原页面:https://cloud.tencent.com/document/product/436/7778

签名步骤
步骤1:生成 KeyTime

    获取当前时间对应的 Unix 时间戳 StartTimestamp,Unix 时间戳是从 UTC(协调世界时,或 GMT 格林威治时间)1970年1月1日0时0分0秒(北京时间 1970年1月1日8时0分0秒)起至现在的总秒数。
    根据上述时间戳和期望的签名有效时长算出签名过期时间对应的 Unix 时间戳 EndTimestamp。
    拼接签名有效时间,格式为StartTimestamp;EndTimestamp,即为 KeyTime。
    示例:1557902800;1557910000

步骤2:生成 SignKey

使用 HMAC-SHA1 以 SecretKey 为密钥,以 KeyTime 为消息,计算消息摘要(哈希值),即为 SignKey。
示例:36bcd76dbb8c9f066472fec403df8a34cab34c77

步骤3:生成 UrlParamList 和 HttpParameters

    遍历 HTTP 请求参数,生成 key 到 value 的映射 Map 及 key 的列表 KeyList,其中 key 转换为小写形式,value 使用 UrlEncode 编码,没有 value 的参数,则认为 value 为空字符串。例如请求路径为/?acl,则认为是/?acl=。

        说明:

        HTTP 请求参数,即请求路径中?以后的部分,例如请求路径为/?versions&prefix=example-folder%2F&delimiter=%2F&max-keys=10,则请求参数为versions&prefix=example-folder%2F&delimiter=%2F&max-keys=10。

    将 KeyList 按照字典序排序。
    将 Map 和 KeyList 中的 key 使用 UrlEncode 编码,并再次转换为小写形式。
    按照 KeyList 的顺序拼接 Map 中的每一个键值对,格式为key1=value1&key2=value2&key3=value3,即为 HttpParameters。
    按照 KeyList 的顺序拼接 KeyList 中的每一项,格式为key1;key2;key3,即为 UrlParamList。

示例:

    示例一:
    请求路径:/?prefix=example-folder%2F&delimiter=%2F&max-keys=10
    UrlParamList: delimiter;max-keys;prefix
    HttpParameters: delimiter=%2F&max-keys=10&prefix=example-folder%2F

        注意:

       请求路径中的请求参数在实际发送请求时也会进行 UrlEncode,因此要注意不要重复执行 UrlEncode。

    示例二:
    请求路径:/exampleobject?acl
    UrlParamList: acl
    HttpParameters: acl=

步骤4:生成 HeaderList 和 HttpHeaders

    遍历 HTTP 请求头部,生成 key 到 value 的映射 Map 及 key 的列表 KeyList,其中 key 转换为小写形式,value 使用 UrlEncode 编码。
    将 KeyList 按照字典序排序。
    将 Map 和 KeyList 中的 key 使用 UrlEncode 编码,并再次转换为小写形式。
    按照 KeyList 的顺序拼接 Map 中的每一个键值对,格式为key1=value1&key2=value2&key3=value3,即为 HttpHeaders。
    按照 KeyList 的顺序拼接 KeyList 中的每一项,格式为key1;key2;key3,即为 HeaderList。

示例:
请求头:

Host: examplebucket-1250000000.cos.ap-shanghai.myqcloud.com
Date: Thu, 16 May 2019 03:15:06 GMT
x-cos-acl: private
x-cos-grant-read: uin="100000000011"

计算得到 HeaderList 为date;host;x-cos-acl;x-cos-grant-read,HttpHeaders 为date=Thu%2C%2016%20May%202019%2003%3A15%3A06%20GMT&host=examplebucket-1250000000.cos.ap-shanghai.myqcloud.com&x-cos-acl=private&x-cos-grant-read=uin%3D%22100000000011%22。
步骤5:生成 HttpString

根据 HTTP 方法、HTTP 请求路径、HttpParameters 和 HttpHeaders 生成 HttpString,格式为HttpMethod\nUriPathname\nHttpParameters\nHttpHeaders\n。

其中:

    HttpMethod 转换为小写,例如 get 或 put。
    UriPathname 为请求路径,例如/或/exampleobject。
    \n为换行符。如果其中有字符串为空,前后的换行符需要保留,例如get\n/exampleobject\n\n\n。

步骤6:生成 StringToSign

根据 KeyTime 和 HttpString 生成 StringToSign,格式为sha1\nKeyTime\nSHA1(HttpString)\n。
其中:

    sha1 为固定字符串。
    \n为换行符。
    SHA1(HttpString) 为使用 SHA1 对 HttpString 计算的消息摘要。

步骤7:生成 Signature

使用 HMAC-SHA1 以 SignKey 为密钥,以 StringToSign 为消息,计算消息摘要,即为 Signature。
步骤8:生成签名

根据 SecretId、KeyTime、HeaderList、UrlParamList 和 Signature 生成签名,格式为:

q-sign-algorithm=sha1
&q-ak=SecretId
&q-sign-time=KeyTime
&q-key-time=KeyTime
&q-header-list=HeaderList
&q-url-param-list=UrlParamList
&q-signature=Signature

    注意:

    上述格式中的换行仅用于更好的阅读,实际格式并不包含换行。

签名使用

通过 RESTful API 对 COS 发起的 HTTP 签名请求,可以通过以下几种方式传递签名:

    通过标准的 HTTP Authorization 头,例如Authorization: q-sign-algorithm=sha1&q-ak=...&q-sign-time=1557989753;1557996953&...&q-signature=...
    作为 HTTP 请求参数,请注意 UrlEncode,例如/exampleobject?q-sign-algorithm=sha1&q-ak=...&q-sign-time=1557989753%3B1557996953&...&q-signature=...

    说明:

    上述示例中使用...省略了部分具体签名内容。

代码示例
伪代码

KeyTime = [Now];[Expires]
SignKey = HMAC-SHA1([SecretKey], KeyTime)
HttpString = [HttpMethod]\n[HttpURI]\n[HttpParameters]\n[HttpHeaders]\n
StringToSign = sha1\nKeyTime\nSHA1(HttpString)\n
Signature = HMAC-SHA1(SignKey, StringToSign)


发帖前要善用论坛搜索功能,那里可能会有你要找的答案或者已经有人发布过相同内容了,请勿重复发帖。

 楼主| 随拾 发表于 2020-5-14 11:51
本帖最后由 随拾 于 2020-5-14 12:05 编辑

第一步:完成
例如:SignKey = HMAC-SHA1(SecretKey, [q-key-time])计算结果:b7edaa87aeb1c89625d5458f1f65f4882177cb3e

第二步:不知道获取哪些信息([HttpURI]怎么获取?[HttpParameters]怎么获取?[HttpHeaders]怎么获取?)
HttpString = [HttpMethod]\n[HttpURI]\n[HttpParameters]\n[HttpHeaders]\n
例如:计算结果:put\n/2ce2f4253fc8a57aa940c62fe8f85dfd\n\ncontent-length;content-md5;x-cos-security-token;x-cos-storage-class\n

第三步:未进行
StringToSign = [q-sign-algorithm]\n[q-sign-time]\nSHA1-HASH(HttpString)\n
例如:计算结果:sha1\n1588997336;1588999136\nd547da8496116d530457878e3121417d8f5ede6f\n

第四步:未进行
Signature = HMAC-SHA1(SignKey,StringToSign)
例如:计算结果:d081bb0d64da09ae302315ae63acf66c9262479b
 楼主| 随拾 发表于 2020-5-14 12:00
现在是卡在步骤3、步骤4,不熟悉怎么获取
步骤3:生成 UrlParamList 和 HttpParameters
    遍历 HTTP 请求参数,生成 key 到 value 的映射 Map 及 key 的列表 KeyList,其中 key 转换为小写形式,value 使用 UrlEncode 编码,没有 value 的参数,则认为 value 为空字符串。例如请求路径为/?acl,则认为是/?acl=。
        说明:
        HTTP 请求参数,即请求路径中?以后的部分,例如请求路径为/?versions&prefix=example-folder%2F&delimiter=%2F&max-keys=10,则请求参数为versions&prefix=example-folder%2F&delimiter=%2F&max-keys=10。
    将 KeyList 按照字典序排序。    将 Map 和 KeyList 中的 key 使用 UrlEncode 编码,并再次转换为小写形式。    按照 KeyList 的顺序拼接 Map 中的每一个键值对,格式为key1=value1&key2=value2&key3=value3,即为 HttpParameters。    按照 KeyList 的顺序拼接 KeyList 中的每一项,格式为key1;key2;key3,即为 UrlParamList。
示例:
    示例一:    请求路径:/?prefix=example-folder%2F&delimiter=%2F&max-keys=10    UrlParamList: delimiter;max-keys;prefix    HttpParameters: delimiter=%2F&max-keys=10&prefix=example-folder%2F
        注意:
        请求路径中的请求参数在实际发送请求时也会进行 UrlEncode,因此要注意不要重复执行 UrlEncode。
    示例二:    请求路径:/exampleobject?acl    UrlParamList: acl    HttpParameters: acl=
步骤4:生成 HeaderList 和 HttpHeaders
    遍历 HTTP 请求头部,生成 key 到 value 的映射 Map 及 key 的列表 KeyList,其中 key 转换为小写形式,value 使用 UrlEncode 编码。    将 KeyList 按照字典序排序。    将 Map 和 KeyList 中的 key 使用 UrlEncode 编码,并再次转换为小写形式。    按照 KeyList 的顺序拼接 Map 中的每一个键值对,格式为key1=value1&key2=value2&key3=value3,即为 HttpHeaders。    按照 KeyList 的顺序拼接 KeyList 中的每一项,格式为key1;key2;key3,即为 HeaderList。
示例:请求头:
Host: examplebucket-1250000000.cos.ap-shanghai.myqcloud.comDate: Thu, 16 May 2019 03:15:06 GMTx-cos-acl: privatex-cos-grant-read: uin="100000000011"
计算得到 HeaderList 为date;host;x-cos-acl;x-cos-grant-read,HttpHeaders 为date=Thu%2C%2016%20May%202019%2003%3A15%3A06%20GMT&host=examplebucket-1250000000.cos.ap-shanghai.myqcloud.com&x-cos-acl=private&x-cos-grant-read=uin%3D%22100000000011%22。
 楼主| 随拾 发表于 2020-5-14 14:38
您需要登录后才可以回帖 登录 | 注册[Register]

本版积分规则

返回列表

RSS订阅|小黑屋|处罚记录|联系我们|吾爱破解 - LCG - LSG ( 京ICP备16042023号 | 京公网安备 11010502030087号 )

GMT+8, 2025-1-15 17:17

Powered by Discuz!

Copyright © 2001-2020, Tencent Cloud.

快速回复 返回顶部 返回列表