站長資訊網
        最全最豐富的資訊網站

        API常用簽名驗證方法(PHP實現)

        使用場景

        現在越來越多的項目使用的前后端分離的模式進行開發,后端開發人員使用API接口傳遞數據給到前端開發進行處理展示,在一些比較重要的修改數據接口,涉及金錢,用戶信息等修改的接口如果不做防護驗證,經常容易被人惡意刷接口,導致巨大的損失。

        API簽名驗證

        這里我們引入業內比較通用的簽名驗證來對接口進行參數加密,有以下優勢。

        • 請求的唯一性:計算出的簽名是唯一的,可以用來驗證。

        • 參數的可變性:參數中包含時間戳參數,這就保證每次的請求計算出得簽名都是不一樣的。

        • 請求的時效:由于請求中帶有當前發起請求的時間戳參數,服務端可以對時間戳進行驗證,過濾超出時效的請求。

        • 安全性:即使請求被人惡意抓包,對方惡意篡改其中的參數,那么簽名都是錯誤的,參數無法修改。

        實踐出真理

        1. 對map類型(即一組鍵值對)的待簽名數據根據鍵的大小進行排序。map中各參數按字母順序排序,如果第一個字母相同,按第二個字母排序,依次類推。例如

        {     "timestamp": "2017-06-08 09:38:00",     "format": "xml",     "app_id": "aabbc",     "cp_extend_info": "",     "sign_type": "HMAC-SHA1",     "sign": "abc" }

        那么,排序后變成

        {     "app_id": "aabbc",     "cp_extend_info": "",     "format": "xml",     "sign_type": "HMAC-SHA1",     "timestamp": "2017-06-08 09:38:00" }

        注意:如果map中包含簽名的參數(sign)需要過濾該參數的鍵值不參與簽名,沒有值的參數請不要參與簽名

        2. 對排序后的map進行序列化處理成待簽名字符串,拼接后的待簽名字符串為

        app_id=aabbc&format=xml&sign_type=HMAC-SHA1&timestamp=2017-06-08 09:38:00

        3. 根據HMAC-SHA1算法使用密鑰提取待簽名字符串的摘要(hash)簽名并進行base64_encode編碼(便于顯性傳輸和對比),假設簽名密鑰為 test ,則提取出的摘要簽名并進行base64_encode的值為

        JqoEqPIVVor0eyRHMYiZftsycVo=

        注意:由于有些數據根據HTTP協議需求,在網絡傳輸過程中需要進行URLencoding,這樣接收方才可以接收到正確的參數,但如果這個參數參與簽名,那么待簽名字符串必須是字符串原值而非URLencoding 的值。

        代碼實踐

        PHP示例

        /**  * 使用密鑰生成HMAC-Sha1簽名  * @param array $params 請求參數  * @param string $signKey 簽名密鑰  * @return string  */ function hmacSha1Sign($params,$signKey) {     ksort($params);       $paramString = '';     foreach ($params as $key => $value) {         if (is_null($value) || $value=='' || $key == 'sign') {             continue;         }         $paramString .= $key.'='.$value.'&';     }     $paramString = substr($paramString,0,-1);     $sign = base64_encode(hash_hmac("sha1", $paramString, $signKey, $raw_output=TRUE));     return $sign; }

        贊(0)
        分享到: 更多 (0)
        網站地圖   滬ICP備18035694號-2    滬公網安備31011702889846號
        主站蜘蛛池模板: 秋霞久久国产精品电影院| 久久乐国产精品亚洲综合| 一级成人精品h| 亚洲精品国产日韩无码AV永久免费网| 精品国产欧美另类一区| 久久夜色精品国产欧美乱| 日韩精品一区二三区中文| 国产精品天干天干在线综合 | 精品久久人人爽天天玩人人妻| 国产精品福利网站导航| 久久99精品国产自在现线小黄鸭 | 国产亚洲美女精品久久久久狼| 人妻精品久久久久中文字幕69 | 国产精品自在线拍国产电影 | 国产麻豆一精品一AV一免费| 亚洲婷婷国产精品电影人久久| 精品视频一区二区三区| 99精品影院| 2022国产精品最新在线| 久久青草国产精品一区| 久久99国产精品久久99果冻传媒| 99久久这里只有精品| 久久er99热精品一区二区| 午夜精品一区二区三区免费视频 | 色花堂国产精品第一页| 欧美大片日韩精品| 四虎影永久在线观看精品| 欧美精品免费在线| 午夜精品在线观看| 91精品福利在线观看| 亚洲精品在线观看视频| 91精品国产自产在线观看| 国产成人毛片亚洲精品| 国产精品自在拍一区二区不卡| 国产午夜精品一区二区| 国产精品伊人久久伊人电影| 国产午夜精品一区二区三区小说 | 91麻豆精品一二三区在线 | 亚洲精品乱码久久久久久自慰| | 亚洲电影日韩精品|