HTTPS連接過程以及Android開發(fā)防止中間人攻擊劫持

HTTPS 原理:https://baijiahao.baidu.com/s?id=1570143475599137&wfr=spider&for=pc

一 义钉、HTTPS連接過程及中間人攻擊原理

HTTPS 協(xié)議(HyperText Transfer Protocol over Secure Socket Layer):可以理解為HTTP+SSL/TLS仙逻, 即 HTTP 下加入 SSL 層拒啰。HTTP+加密+認(rèn)證+完整保護(hù)=HTTPS


http&https

HTTPS 的連接過程如下所示:

1.https請求

客戶端向服務(wù)端發(fā)送https請求;

2.生成公鑰和私鑰

服務(wù)端收到請求之后,生成公鑰和私鑰电谣。公鑰相當(dāng)于是鎖,私鑰相當(dāng)于是鑰匙蛔钙,只有私鑰才能夠打開公鑰鎖住的內(nèi)容;

3.返回公鑰

服務(wù)端將公鑰(證書)返回給客戶端储矩,公鑰里面包含有很多信息感耙,比如證書的頒發(fā)機(jī)構(gòu)、過期時間等等;

4.客戶端驗證公鑰

客戶端收到公鑰之后持隧,首先會驗證其是否有效即硼,如頒發(fā)機(jī)構(gòu)或者過期時間等,如果發(fā)現(xiàn)有問題就會拋出異常屡拨,提示證書存在問題只酥。如果沒有問題,那么就生成一個隨機(jī)值呀狼,作為客戶端的密鑰裂允,然后用服務(wù)端的公鑰加密;

5.發(fā)送客戶端密鑰

客戶端用服務(wù)端的公鑰加密密鑰,然后發(fā)送給服務(wù)端哥艇。

6.服務(wù)端收取密鑰绝编,對稱加密內(nèi)容

服務(wù)端收到經(jīng)過加密的密鑰,然后用私鑰將其解密貌踏,得到客戶端的密鑰十饥,然后服務(wù)端把要傳輸?shù)膬?nèi)容和客戶端的密鑰進(jìn)行對稱加密,這樣除非知道密鑰祖乳,否則無法知道傳輸?shù)膬?nèi)容绷跑。

7.加密傳輸

服務(wù)端將經(jīng)過加密的內(nèi)容傳輸給客戶端。

8.獲取加密內(nèi)容凡资,解密

客戶端獲取加密內(nèi)容后砸捏,用之前生成的密鑰對其進(jìn)行解密,獲取到內(nèi)容隙赁。

中間人劫持攻擊

https也不是絕對安全的垦藏,如下圖所示為中間人劫持攻擊,中間人可以獲取到客戶端與服務(wù)器之間所有的通信內(nèi)容伞访。

中間人截取客戶端發(fā)送給服務(wù)器的請求掂骏,然后偽裝成客戶端與服務(wù)器進(jìn)行通信;將服務(wù)器返回給客戶端的內(nèi)容發(fā)送給客戶端,偽裝成服務(wù)器與客戶端進(jìn)行通信厚掷。

通過這樣的手段弟灼,便可以獲取客戶端和服務(wù)器之間通信的所有內(nèi)容。

使用中間人攻擊手段冒黑,必須要讓客戶端信任中間人的證書田绑,如果客戶端不信任,則這種攻擊手段也無法發(fā)揮作用抡爹。

二掩驱、中間人攻擊的預(yù)防

造成中間人劫持的原因是 沒有對服務(wù)端證書及域名做校驗或者校驗不完整,為了方便,直接采用開源框架默認(rèn)的校驗方式進(jìn)行https請求

OKhttp3.0

預(yù)防方法:

預(yù)防方式有兩種

1 欧穴、針對安全性要求比較高的 app民逼,可采取客戶端預(yù)埋證書的方式鎖死證書,只有當(dāng)客戶端證書和服務(wù)端的證書完全一致的情況下才允許通信涮帘,如一些銀行類的app拼苍,但這種方式面臨一個問題,證書過期的問題调缨,因證書有一定的有效期映屋,當(dāng)預(yù)埋證書過期了,只有通過強(qiáng)制更新或者要求用戶下載證書來解決同蜻。

生成 經(jīng)過ssl校驗及 域名校驗的connection

域名校驗

2 針對安全性要求一般的app棚点,可采用通過校驗域名,證書有效性湾蔓、證書關(guān)鍵信息及證書鏈的方式

以volley為例瘫析,重寫HTTPSTrustManager 中的checkServerTrusted 方法,同時開啟域名強(qiáng)校驗

三默责、Webview的HTTPS安全

目前很多應(yīng)用都用webview加載H5頁面贬循,如果服務(wù)端采用的是可信CA頒發(fā)的證書,在 webView.setWebViewClient(webviewClient) 時重載 WebViewClient的onReceivedSslError() 桃序,如果出現(xiàn)證書錯誤杖虾,直接調(diào)用handler.proceed()會忽略錯誤繼續(xù)加載證書有問題的頁面,如果調(diào)用handler.cancel()可以終止加載證書有問題的頁面媒熊,證書出現(xiàn)問題了奇适,可以提示用戶風(fēng)險,讓用戶選擇加載與否芦鳍,如果是需要安全級別比較高嚷往,可以直接終止頁面加載,提示用戶網(wǎng)絡(luò)環(huán)境有風(fēng)險:

不建議直接用handler.proceed()柠衅。如果webview加載https需要強(qiáng)校驗服務(wù)端證書皮仁,可以在 onPageStarted() 中用 HttpsURLConnection 強(qiáng)校驗證書的方式來校驗服務(wù)端證書,如果校驗不通過停止加載網(wǎng)頁菲宴。當(dāng)然這樣會拖慢網(wǎng)頁的加載速度贷祈,需要進(jìn)一步優(yōu)化,具體優(yōu)化的辦法不在本次討論范圍喝峦,這里也不詳細(xì)講解

總結(jié)

  • 建議自定義實現(xiàn)X509TrustManager時势誊,在checkServerTrusted中對服務(wù)器信息進(jìn)行嚴(yán)格校驗
  • 在重寫WebViewClient的onReceivedSslError方法時,避免調(diào)用proceed忽略證書驗證錯誤信息繼續(xù)加載頁面
  • 在自定義實現(xiàn)HostnameVerifier時愈犹,在verify中對Hostname進(jìn)行嚴(yán)格校驗
  • 建議setHostnameVerifier方法中使用STRICT_HOSTNAME_VERIFIER進(jìn)行嚴(yán)格證書校驗键科,避免使用ALLOW_ALL_HOSTNAME_VERIFIER
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末闻丑,一起剝皮案震驚了整個濱河市漩怎,隨后出現(xiàn)的幾起案子勋颖,更是在濱河造成了極大的恐慌,老刑警劉巖勋锤,帶你破解...
    沈念sama閱讀 206,602評論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件饭玲,死亡現(xiàn)場離奇詭異,居然都是意外死亡叁执,警方通過查閱死者的電腦和手機(jī)茄厘,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,442評論 2 382
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來谈宛,“玉大人次哈,你說我怎么就攤上這事∵郝迹” “怎么了窑滞?”我有些...
    開封第一講書人閱讀 152,878評論 0 344
  • 文/不壞的土叔 我叫張陵,是天一觀的道長恢筝。 經(jīng)常有香客問我哀卫,道長,這世上最難降的妖魔是什么撬槽? 我笑而不...
    開封第一講書人閱讀 55,306評論 1 279
  • 正文 為了忘掉前任此改,我火速辦了婚禮,結(jié)果婚禮上侄柔,老公的妹妹穿的比我還像新娘共啃。我一直安慰自己,他們只是感情好暂题,可當(dāng)我...
    茶點故事閱讀 64,330評論 5 373
  • 文/花漫 我一把揭開白布勋磕。 她就那樣靜靜地躺著,像睡著了一般敢靡。 火紅的嫁衣襯著肌膚如雪挂滓。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,071評論 1 285
  • 那天啸胧,我揣著相機(jī)與錄音赶站,去河邊找鬼。 笑死纺念,一個胖子當(dāng)著我的面吹牛贝椿,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播陷谱,決...
    沈念sama閱讀 38,382評論 3 400
  • 文/蒼蘭香墨 我猛地睜開眼烙博,長吁一口氣:“原來是場噩夢啊……” “哼瑟蜈!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起渣窜,我...
    開封第一講書人閱讀 37,006評論 0 259
  • 序言:老撾萬榮一對情侶失蹤铺根,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后乔宿,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體位迂,經(jīng)...
    沈念sama閱讀 43,512評論 1 300
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 35,965評論 2 325
  • 正文 我和宋清朗相戀三年详瑞,在試婚紗的時候發(fā)現(xiàn)自己被綠了掂林。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 38,094評論 1 333
  • 序言:一個原本活蹦亂跳的男人離奇死亡坝橡,死狀恐怖泻帮,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情计寇,我是刑警寧澤锣杂,帶...
    沈念sama閱讀 33,732評論 4 323
  • 正文 年R本政府宣布,位于F島的核電站饲常,受9級特大地震影響蹲堂,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜贝淤,卻給世界環(huán)境...
    茶點故事閱讀 39,283評論 3 307
  • 文/蒙蒙 一柒竞、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧播聪,春花似錦朽基、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,286評論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至招刨,卻和暖如春霎俩,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背沉眶。 一陣腳步聲響...
    開封第一講書人閱讀 31,512評論 1 262
  • 我被黑心中介騙來泰國打工打却, 沒想到剛下飛機(jī)就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人谎倔。 一個月前我還...
    沈念sama閱讀 45,536評論 2 354
  • 正文 我出身青樓柳击,卻偏偏與公主長得像,于是被迫代替她去往敵國和親片习。 傳聞我的和親對象是個殘疾皇子捌肴,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 42,828評論 2 345

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