安全篇-AES/RSA加密機制

在服務器與終端設備進行HTTP通訊時,常常會被網(wǎng)絡抓包蜡饵、反編譯(Android?APK反編譯工具)等技術得到HTTP通訊接口地址和參數(shù)。為了確保信息的安全,我們采用AES+RSA組合的方式進行接口參數(shù)加密和解密鬓梅。

1.關于RSA加密機制:公鑰用于對數(shù)據(jù)進行加密,私鑰對數(shù)據(jù)進行解密谨湘,兩者不可逆绽快。公鑰和私鑰是同時生成的,一一對應紧阔。比如:A擁有公鑰坊罢,B擁有公鑰和私鑰。A將數(shù)據(jù)通過公鑰進行加密后擅耽,發(fā)送密文給B活孩,B可以通過私鑰和公鑰進行解密。

2.AES加密也叫對稱加密:A用密碼對數(shù)據(jù)進行AES加密后乖仇,B用同樣的密碼對密文進行AES解密憾儒。


?具體操作方法:

1.在終端中采用openssl方式輸入密鑰的相關屬性(公司名询兴、郵箱等),然后在終端當前所在的地址下起趾,生成公鑰和私鑰共7個文件(7個文件如何使用請看附錄的拓展了鏈接)蕉朵。

2.此時假設Android客戶端擁有公鑰PublicKey,服務器端擁有公鑰PublicKey和私鑰PrivateKey。

3.安卓發(fā)送請求到服務器端:安卓隨機生成Byte[]隨機密碼阳掐,假設RandomKey=“123456”始衅,通過AES算法,對Json數(shù)據(jù)利用進行加密缭保。

4.但是此刻服務器并不知道客戶端的RandomKey是什么汛闸,因此需要同時將Randomkey傳給服務器,否則服務器無法通過AES對Json數(shù)據(jù)進行解密艺骂。但是如果直接發(fā)送請求诸老,Randomkey就會暴露,所以要對RandomKey進行不可逆的RSA加密钳恕。

5.安卓將使用Randomkey進行AES加密的Json數(shù)據(jù)别伏,和使用PublicKey進行RSA加密的RandomKey通過HTTP傳送到服務器端。數(shù)據(jù)請求工作完成忧额。

6.服務器端接收到AES加密的Json數(shù)據(jù)和Rsa加密的RandomKey數(shù)據(jù)厘肮。

7.服務器通過私鑰PrivateKey對加密后的RandomKey進行Rsa解密。得到安卓生成的原始Randomkey睦番。

8.利用原始的RandomKey對加密后的Json數(shù)據(jù)進行AES對稱解密类茂。至此已經(jīng)得到安卓端發(fā)過來的原始Json數(shù)據(jù)。進行常規(guī)的服務器業(yè)務操作托嚣,然后將返回數(shù)據(jù)通過安卓端的RandomKey進行AES加密gouhou后巩检,Response返回。

9.安卓端接收到Response的數(shù)據(jù)后示启,利用之前本地生成的RandomKey直接進行AES解密即可兢哭。

詳細的流程圖可以查看下圖。


客戶端-服務器端HTTPS數(shù)據(jù)傳輸流程圖

注意事項:

1.在實際的開發(fā)過程中夫嗓,發(fā)現(xiàn)RSA和AES有不同的密文生成標準迟螺,會不兼容IOS。IOS在RSA算法中需要的公鑰與JAVA不同啤月。詳細的解決方案請查看:http://www.cnblogs.com/makemelike/articles/3802518.html

2.AES加密不可以使用超過128Byte的KEY煮仇,因為在jdk1.7以上的版本不支持超過128Byte的KEY劳跃。

小結:從性能上來測谎仲,整個客戶端送加密數(shù)據(jù)開始到解密得到回傳的原始數(shù)據(jù)不超過300ms(Iphone4和Centos Java服務器傳輸測試)。本方案沒有采用TOKEN的方式刨仑,或許以后用到郑诺。公鑰如何更新也需要繼續(xù)完善夹姥。

附:具體的JAVA和IOS加密解密Demo遲點整理給出。

最后編輯于
?著作權歸作者所有,轉載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末辙诞,一起剝皮案震驚了整個濱河市辙售,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌飞涂,老刑警劉巖旦部,帶你破解...
    沈念sama閱讀 218,941評論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異较店,居然都是意外死亡士八,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,397評論 3 395
  • 文/潘曉璐 我一進店門梁呈,熙熙樓的掌柜王于貴愁眉苦臉地迎上來婚度,“玉大人,你說我怎么就攤上這事官卡』茸拢” “怎么了?”我有些...
    開封第一講書人閱讀 165,345評論 0 356
  • 文/不壞的土叔 我叫張陵寻咒,是天一觀的道長哮翘。 經(jīng)常有香客問我,道長毛秘,這世上最難降的妖魔是什么忍坷? 我笑而不...
    開封第一講書人閱讀 58,851評論 1 295
  • 正文 為了忘掉前任,我火速辦了婚禮熔脂,結果婚禮上佩研,老公的妹妹穿的比我還像新娘。我一直安慰自己霞揉,他們只是感情好旬薯,可當我...
    茶點故事閱讀 67,868評論 6 392
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著适秩,像睡著了一般绊序。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上秽荞,一...
    開封第一講書人閱讀 51,688評論 1 305
  • 那天骤公,我揣著相機與錄音,去河邊找鬼扬跋。 笑死阶捆,一個胖子當著我的面吹牛,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播洒试,決...
    沈念sama閱讀 40,414評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼倍奢,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了垒棋?” 一聲冷哼從身側響起卒煞,我...
    開封第一講書人閱讀 39,319評論 0 276
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎叼架,沒想到半個月后畔裕,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,775評論 1 315
  • 正文 獨居荒郊野嶺守林人離奇死亡乖订,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,945評論 3 336
  • 正文 我和宋清朗相戀三年柴钻,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片垢粮。...
    茶點故事閱讀 40,096評論 1 350
  • 序言:一個原本活蹦亂跳的男人離奇死亡贴届,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出蜡吧,到底是詐尸還是另有隱情毫蚓,我是刑警寧澤,帶...
    沈念sama閱讀 35,789評論 5 346
  • 正文 年R本政府宣布昔善,位于F島的核電站元潘,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏君仆。R本人自食惡果不足惜翩概,卻給世界環(huán)境...
    茶點故事閱讀 41,437評論 3 331
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望返咱。 院中可真熱鬧钥庇,春花似錦、人聲如沸咖摹。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,993評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽萤晴。三九已至吐句,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間店读,已是汗流浹背嗦枢。 一陣腳步聲響...
    開封第一講書人閱讀 33,107評論 1 271
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留屯断,地道東北人文虏。 一個月前我還...
    沈念sama閱讀 48,308評論 3 372
  • 正文 我出身青樓侣诺,卻偏偏與公主長得像,于是被迫代替她去往敵國和親择葡。 傳聞我的和親對象是個殘疾皇子紧武,可洞房花燭夜當晚...
    茶點故事閱讀 45,037評論 2 355

推薦閱讀更多精彩內(nèi)容