Api 接口安全-防篡改,防重放理解總結

防篡改

為什么要防篡改

http 是一種無狀態(tài)的協(xié)議, 服務端并不知道客戶端發(fā)送的請求是否合法, 也并不知道請求中的參數(shù)是否正確
舉個栗子, 現(xiàn)在有個充值的接口, 調用給用戶對應的余額

http://localhost/api/user/recharge?user_id=1001&amount=10
  1. 給指定id的用戶加上10塊錢的余額
  2. 如果用戶id被篡改,余額參數(shù)被篡改,也就是說,可以給任何用戶加余額

如何防篡改 - 設計sign

  1. 客戶端: 每次請求客戶端都帶一個 sign 參數(shù)給服務端, 這個所謂的 sign 就是一個字符串
  2. 服務端: 每次處理請求之前先驗證 sign 是否合法, 如果不合法就不處理
  3. 生成 sign 和驗證 sign: 怎么生成和驗證, 需要客戶端和服務端約定好
    3.1. 客戶端生成 sign: 可使用 公私鑰非對稱加密 的方式, 也可以使用計算字符串 md5 或者 hash 值的方式, 這個被加密的字符串最好不是固定的,取時間戳, 請求參數(shù)等就可以, 每次客戶端把生成sign傳遞給服務端
    3.2. 服務端根據(jù)約定好的算法驗證sign是否正確就可以

不一定非得叫 sign 這么個名字, 就是個請求參數(shù)的名稱而已

http://localhos/api/assets/recharge?id=1001&amount=10&sign=asdfasdf6sdfs87f67

防重放

設計了防篡改之后, 接口總算是安全了那么一點點, 但是還不夠...還需要對接口設計防重放設置

為什么要防重放

防重放也叫防復用,簡單來說,就是我獲取到這個請求的信息之后, 我什么也不改, 我就拿著接口的參數(shù)去 重復請求這個充值的接口,也就是說我的請求是合法的, 因為所有參數(shù)都是跟合法請求一模一樣的,也就是說: 服務端的 sign 驗證一定能通過, 但是此時, 我可以去重復請求這個充值的接口, 也就是我能夠重復的充值(假設這個接口沒有做其他邏輯處理,調用就能充值,我只是假設, 別抬杠), 調用一次加 10 塊錢余額, 2次就是20...這就不合理了

防重放設計

  1. 客戶端在請求中添加兩個參數(shù)
    1.1 添加一個隨機不重復的字符串參數(shù) 比如uuid 至于怎么讓他不重復,可以考慮拼接時間戳,md5隨機數(shù)等
    1.2 添加一個請求時間的參數(shù) 如 request_time 值就是發(fā)送請求時的 時間戳

  2. 服務端接收到請求之后:
    2.1 去緩存里中查找 uuid 這個參數(shù)對應的值是否存在
    2.2 如果不存在: 就把這個uuid的值保存到緩存中, 記錄這個請求
    2.3 如果已存在: 存在那就證明, 已經(jīng)請求過一次了, 就不處理這個請求了

緩存可以是redis也可以是其他存儲介質,應該給緩存設計過期時間,因為請求多了,就會有大量的 uuid 保存在緩存中

參考

這個防重放的設計是參考了這位前輩的經(jīng)驗總結, 有時間可以看看
https://learnku.com/articles/4196/talk-about-the-anti-replay-mechanism-of-api

http://localhos/api/assets/recharge?id=1001&amount=10&sign=asdfasdffs87f67&request_time=1561095355627&uuid=1561095355627aUjKs
最后編輯于
?著作權歸作者所有,轉載或內容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌邑遏,老刑警劉巖殖蚕,帶你破解...
    沈念sama閱讀 206,723評論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件畦娄,死亡現(xiàn)場離奇詭異俩垃,居然都是意外死亡铸豁,警方通過查閱死者的電腦和手機蜈垮,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,485評論 2 382
  • 文/潘曉璐 我一進店門耗跛,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人窃款,你說我怎么就攤上這事课兄。” “怎么了晨继?”我有些...
    開封第一講書人閱讀 152,998評論 0 344
  • 文/不壞的土叔 我叫張陵烟阐,是天一觀的道長。 經(jīng)常有香客問我紊扬,道長蜒茄,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 55,323評論 1 279
  • 正文 為了忘掉前任餐屎,我火速辦了婚禮檀葛,結果婚禮上,老公的妹妹穿的比我還像新娘腹缩。我一直安慰自己屿聋,他們只是感情好空扎,可當我...
    茶點故事閱讀 64,355評論 5 374
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著润讥,像睡著了一般转锈。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上楚殿,一...
    開封第一講書人閱讀 49,079評論 1 285
  • 那天撮慨,我揣著相機與錄音,去河邊找鬼脆粥。 笑死砌溺,一個胖子當著我的面吹牛,可吹牛的內容都是我干的变隔。 我是一名探鬼主播规伐,決...
    沈念sama閱讀 38,389評論 3 400
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼弟胀!你這毒婦竟也來了楷力?” 一聲冷哼從身側響起喊式,我...
    開封第一講書人閱讀 37,019評論 0 259
  • 序言:老撾萬榮一對情侶失蹤孵户,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后岔留,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體夏哭,經(jīng)...
    沈念sama閱讀 43,519評論 1 300
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 35,971評論 2 325
  • 正文 我和宋清朗相戀三年献联,在試婚紗的時候發(fā)現(xiàn)自己被綠了竖配。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 38,100評論 1 333
  • 序言:一個原本活蹦亂跳的男人離奇死亡里逆,死狀恐怖进胯,靈堂內的尸體忽然破棺而出,到底是詐尸還是另有隱情原押,我是刑警寧澤胁镐,帶...
    沈念sama閱讀 33,738評論 4 324
  • 正文 年R本政府宣布,位于F島的核電站诸衔,受9級特大地震影響盯漂,放射性物質發(fā)生泄漏。R本人自食惡果不足惜笨农,卻給世界環(huán)境...
    茶點故事閱讀 39,293評論 3 307
  • 文/蒙蒙 一就缆、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧谒亦,春花似錦竭宰、人聲如沸空郊。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,289評論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽渣淳。三九已至,卻和暖如春伴箩,著一層夾襖步出監(jiān)牢的瞬間入愧,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 31,517評論 1 262
  • 我被黑心中介騙來泰國打工嗤谚, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留棺蛛,地道東北人。 一個月前我還...
    沈念sama閱讀 45,547評論 2 354
  • 正文 我出身青樓巩步,卻偏偏與公主長得像旁赊,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子椅野,可洞房花燭夜當晚...
    茶點故事閱讀 42,834評論 2 345