【轉(zhuǎn)載】騰訊API SecretId 與 SecretKey 鑒權(quán)

騰訊云 API 使用簽名方法(Signature)對(duì)接口進(jìn)行鑒權(quán)荚斯。每一次請求都需要在請求中包含簽名信息, 以驗(yàn)證用戶身份让网。
在第一次使用云API之前嘁灯,用戶首先需要在騰訊云網(wǎng)站上申請安全憑證,安全憑證包括 SecretId 和 SecretKey, SecretId 是用于標(biāo)識(shí) API 調(diào)用者的身份靶病,SecretKey是用于加密簽名字符串和服務(wù)器端驗(yàn)證簽名字符串的密鑰会通。SecretKey 必須嚴(yán)格保管。避免泄露娄周。

  1. 申請安全憑證

  2. 登錄 騰訊云, 進(jìn)入 管理中心 頁面

  3. 點(diǎn)擊 管理賬號(hào) 下的 安全憑證 鏈接, 進(jìn)入 云API訪問密鑰管理 頁面

  4. 在 云API訪問密鑰管理 頁面可以新建 SecretId, 每個(gè)帳號(hào)最多可以創(chuàng)建兩個(gè) SecretId

  5. 生成簽名串
    假設(shè)上一步申請的 SecretId 和 SecretKey 分別是:
    SecretId: AKIDz8krbsJ5yKBZQpn74WFkmLPx3gnPhESA
    SecretKey: Gu5t9xGARNpq86cd98joQYCN3Cozk1qA

以 查詢實(shí)例列表 請求為例, 請求參數(shù)為:
方法名: Action=DescribeInstances
SecretId: SecretId= AKIDz8krbsJ5yKBZQpn74WFkmLPx3gnPhESA
當(dāng)前時(shí)間戳: Timestamp=1408704141
隨機(jī)正整數(shù): Nonce=345122
區(qū)域: Region=gz

接口簽名的詳細(xì)步驟如下:

  1. 對(duì)參數(shù)排序
    對(duì)請求參數(shù)按參數(shù)名做字典序升序排列, 結(jié)果如下:

{ 'Action' : 'DescribeInstances', 'Nonce' : 345122, 'Region' : 'gz', 'SecretId' : 'AKIDz8krbsJ5yKBZQpn74WFkmLPx3gnPhESA', 'Timestamp' : 1408704141}

  1. 拼接請求字符串
    把上一步排序好的請求參數(shù), 格式化成 k=v涕侈,然后用"&"拼接在一起。注意不包括Signature參數(shù)煤辨,v為原始值而非url編碼后的值裳涛。結(jié)果為:

Action=DescribeInstances&Nonce= 345122&Region=gz&SecretId=AKIDz8krbsJ5yKBZQpn74WFkmLPx3gnPhESA&Timestamp=1408704141

  1. 拼接簽名源文字符串
    拼接簽名原文時(shí)需要如下參數(shù):
    請求方法: 支持 POST 和 GET 方式, 這里架設(shè)為 GET 請求, 注意 GET 為全大寫
    請求主機(jī): cvm.api.qcloud.com, 根據(jù)接口所屬模塊不同域名也不同, 詳見接口文檔
    請求路徑: /v2/index.php
    請求字符串: 即前 2 步生成的請求字符串

簽名源文的拼接規(guī)則為:

請求方法 + 請求主機(jī) +請求路徑 + ? + 請求字符串

拼接結(jié)果為:

GETcvm.api.qcloud.com/v2/index.php?Action=DescribeInstances&Nonce= 345122&Region=gz&SecretId=AKIDz8krbsJ5yKBZQpn74WFkmLPx3gnPhESA&Timestamp=1408704141

  1. 生成簽名串
  2. 騰訊云 API 使用 HMAC-SHA1 算法對(duì)請求進(jìn)行簽名
  3. 簽名串需要使用 Base64 編碼
  4. 發(fā)送請求時(shí), 對(duì)簽名串進(jìn)行 Url Encode

以 PHP 語言為例:

secretKey = 'Gu5t9xGARNpq86cd98joQYCN3Cozk1qA';srcStr = 'GETcvm.api.qcloud.com/v2/index.php?Action=DescribeInstances&Nonce=345122&Region=gz&SecretId=AKIDz8krbsJ5yKBZQpn74WFkmLPx3gnPhESA&Timestamp=1408704141';
signStr = base64_encode(hash_hmac('sha1',srcStr, secretKey, true)); echosignStr;

這里得到的簽名串為:

HgIYOPcx5lN6gz8JsCFBNAWp2oQ=

使用其它程序設(shè)計(jì)語言開發(fā)時(shí), 可用上面示例中的原文進(jìn)行簽名驗(yàn)證, 得到的簽名串與例子中的一致即可

  1. 添加簽名, 發(fā)送請求
  2. 請求參數(shù)中添加 Signature 參數(shù), 參數(shù)值為上一步生成的簽名串, 并且對(duì)簽名進(jìn)行 Url Encode
  3. 發(fā)送 HTTPS 協(xié)議的 GET 請求即可得到 JSON 字符串格式的接口返回值

最終的請求 URL 為:

https://cvm.api.qcloud.com/v2/index.php?Action=DescribeInstances&Nonce=345122&Region=gz&SecretId=AKIDz8krbsJ5yKBZQpn74WFkmLPx3gnPhESA&Signature=HgIYOPcx5lN6gz8JsCFBNAWp2oQ%3D&Timestamp=1408704141

將示例代碼中的 YOUR_SECRET_ID 和 YOUR_SECRET_KEY 替換成實(shí)際的 SecretId 和 SecretKey
示例代碼僅供參考, 請根據(jù)實(shí)際情況使用众辨。

原文:
http://www.qcloud.com/wiki/接口鑒權(quán)

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末端三,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子泻轰,更是在濱河造成了極大的恐慌技肩,老刑警劉巖,帶你破解...
    沈念sama閱讀 219,110評(píng)論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件浮声,死亡現(xiàn)場離奇詭異虚婿,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)泳挥,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,443評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門然痊,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人屉符,你說我怎么就攤上這事剧浸。” “怎么了矗钟?”我有些...
    開封第一講書人閱讀 165,474評(píng)論 0 356
  • 文/不壞的土叔 我叫張陵唆香,是天一觀的道長。 經(jīng)常有香客問我吨艇,道長躬它,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,881評(píng)論 1 295
  • 正文 為了忘掉前任东涡,我火速辦了婚禮冯吓,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘疮跑。我一直安慰自己组贺,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,902評(píng)論 6 392
  • 文/花漫 我一把揭開白布祖娘。 她就那樣靜靜地躺著失尖,像睡著了一般。 火紅的嫁衣襯著肌膚如雪渐苏。 梳的紋絲不亂的頭發(fā)上掀潮,一...
    開封第一講書人閱讀 51,698評(píng)論 1 305
  • 那天,我揣著相機(jī)與錄音整以,去河邊找鬼胧辽。 笑死,一個(gè)胖子當(dāng)著我的面吹牛公黑,可吹牛的內(nèi)容都是我干的邑商。 我是一名探鬼主播,決...
    沈念sama閱讀 40,418評(píng)論 3 419
  • 文/蒼蘭香墨 我猛地睜開眼凡蚜,長吁一口氣:“原來是場噩夢啊……” “哼人断!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起朝蜘,我...
    開封第一講書人閱讀 39,332評(píng)論 0 276
  • 序言:老撾萬榮一對(duì)情侶失蹤恶迈,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體暇仲,經(jīng)...
    沈念sama閱讀 45,796評(píng)論 1 316
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡步做,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,968評(píng)論 3 337
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了奈附。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片全度。...
    茶點(diǎn)故事閱讀 40,110評(píng)論 1 351
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖斥滤,靈堂內(nèi)的尸體忽然破棺而出将鸵,到底是詐尸還是另有隱情,我是刑警寧澤佑颇,帶...
    沈念sama閱讀 35,792評(píng)論 5 346
  • 正文 年R本政府宣布顶掉,位于F島的核電站,受9級(jí)特大地震影響挑胸,放射性物質(zhì)發(fā)生泄漏痒筒。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,455評(píng)論 3 331
  • 文/蒙蒙 一嗜暴、第九天 我趴在偏房一處隱蔽的房頂上張望凸克。 院中可真熱鬧,春花似錦闷沥、人聲如沸萎战。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,003評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽蚂维。三九已至,卻和暖如春路狮,著一層夾襖步出監(jiān)牢的瞬間虫啥,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,130評(píng)論 1 272
  • 我被黑心中介騙來泰國打工奄妨, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留涂籽,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 48,348評(píng)論 3 373
  • 正文 我出身青樓砸抛,卻偏偏與公主長得像评雌,于是被迫代替她去往敵國和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子直焙,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,047評(píng)論 2 355