[iOS筆記] 網路通信安全與證書

来源:http://www.cnblogs.com/afluy/archive/2016/08/09/5754526.html
-Advertisement-
Play Games

非對稱加密演算法 RSA 介紹 1977年,三位數學家Rivest、Shamir 和 Adleman 設計了一種演算法,可以實現非對稱加密。 演算法原理: https://zh.wikipedia.org/wiki/RSA%E5%8A%A0%E5%AF%86%E6%BC%94%E7%AE%97%E6%B3 ...


非對稱加密演算法 RSA

介紹

1977年,三位數學家Rivest、Shamir 和 Adleman 設計了一種演算法,可以實現非對稱加密。

演算法原理:

https://zh.wikipedia.org/wiki/RSA%E5%8A%A0%E5%AF%86%E6%BC%94%E7%AE%97%E6%B3%95

流程

  • 消息發送方A在本地構建密鑰對,公鑰和私鑰;

  • 消息發送方A將產生的公鑰發送給消息接收方B;

  • B向A發送數據時,通過公鑰進行加密,A接收到數據後通過私鑰進行解密,完成一次通信;

  • 反之,A向B發送數據時,通過私鑰對數據進行加密,B接收到數據後通過公鑰進行解密。

DH密鑰交換演算法

介紹

1976年,兩位美國電腦學家Whitfield Diffie 和 Martin Hellman,提出了一種嶄新構思,可以在不直接傳遞密鑰的情況下,完成解密。

DH演算法是一種密鑰協商演算法,只用於密鑰的分配,不用於消息的加解密。

它提供了一種安全的交換密鑰的方式,通過交換的密鑰進行數據的加解密。

通信流程

  • 首先A、B雙方,在通信前構建專屬於自己的密鑰對,假設分別是公鑰A,私鑰A,公鑰B,私鑰B;

  • A將自己的公鑰A暴露給B,B通過私鑰B和公鑰A經過一定的運算產生出本地的密鑰B;

  • 同樣,B將自己的公鑰B暴露給A,A通過私鑰A和公鑰B經過一定的運算產生出本地的密鑰A;

  • 最後,這個演算法有意思的一點就是,密鑰A和密鑰B是一致的,這樣A、B雙方就擁有了一個屬於雙方的“秘密”口令;

資料

http://www.ruanyifeng.com/blog/2013/06/rsa_algorithm_part_one.html

http://www.ruanyifeng.com/blog/2011/02/seven_myths_about_https.html

HTTPS

HTTP的風險

  • 竊聽風險:第三方可以獲知通信內容。
  • 冒充風險:第三方可以冒充他人身份參與通信。
  • 篡改風險:第三方可以修改通信內容。

SSL/TLS

介紹

安全套接字(Secure Socket Layer,SSL)

安全傳輸層協議 (Transport Layer Security Protocol, TLS)

介於應用層和TCP層之間

特性

  • 保密: 所有信息都是加密傳播,第三方無法竊聽
  • 鑒別: 配備身份證書,防止身份被冒充。
  • 完整性: 具有校驗機制,一旦被篡改,通信雙方會立刻發現。

密碼套件格式: SSL_DHE_RSA_WITH_DES_CBC_SHA

工作原理

協議
  • 握手協議(Handshake protocol)
  • 記錄協議(Record protocol)
  • 警報協議(Alert protocol)

解決的問題

  • 如何保證公鑰不被篡改?

    將公鑰放在數字證書中。只要證書是可信的,公鑰就是可信的。

  • 公鑰加密計算量太大,如何減少耗用的時間?

"對話密鑰"是對稱加密,所以運算速度非常快,而伺服器公鑰只用於加密"對話密鑰"本身,這樣就減少了加密運算的消耗時間。

對稱和非對稱加密的應用:Secure Shell (SSH 安全殼協議)

介紹

專為遠程登錄會話和其他網路服務提供安全性的協議

一般我們現在用的是OpenSSH框架

OSI的7層:
7 應用層  HTTP FTP
6 表示層 
5 會話層  SSH
4 傳輸層  TCP UDP
3 網路層  IP
2 數據鏈路層 
1 物理層

主要協議

  • 傳輸層協議(The Transport Layer Protocol)
  • 用戶認證協議(The User Authentication Protocol)
  • 連接協議(The Connection Protocol)

SSH提供兩種認證方式:

password認證:

客戶端向伺服器發出 password認證請求,將用戶名和密碼加密後發送給伺服器;

伺服器將該信息解密後得到用戶名和密碼的明文,與設備上保存的用戶名和密碼進行比較,並返回認證成功或失敗的消息。

publickey 認證:

採用數字簽名的方法來認證客戶端。目前,設備上可以利用RSA和 DSA兩種公共密鑰演算法實現數字簽名。

客戶端發送包含用戶名、公共密鑰和公共密鑰演算法的 publickey 認證請求給伺服器端。

伺服器對公鑰進行合法性檢查,如果不合法,則直接發送失敗消息;否則,伺服器利用數字簽名對客戶端進行認證,並返回認證成功或失敗的消息

通信流程
  • 首先服務端會通過非對稱加密,產生一個公鑰和私鑰;

  • 在客戶端發起請求時,服務端將公鑰暴露給客戶端,這個公鑰可以被任意暴露;

  • 客戶端在獲取公鑰後,會先產生一個由256位隨機數字組成的會話密鑰,這裡稱為口令;

  • 客戶端通過公鑰將這個口令加密,發送給伺服器端;

  • 伺服器端通過私鑰進行解密,獲取到通訊口令;

  • 之後,客戶端和服務端的信息傳遞,都通過這個口令進行對稱的加密。 //對稱加密

資料

http://www.cnblogs.com/zmlctt/p/3946860.html

證書 certificate

介紹

證書實際是由證書簽證機關(CA)簽發的對用戶的公鑰的認證。

證書的內容包括:

  • 電子簽證機關的信息
  • 公鑰用戶信息
  • 公鑰
  • 權威機構的簽字
  • 有效期
  • ...

證書中心 (certificate authority,簡稱CA)

受信任的根證書頒發機構, 如: 微軟, Apple

證書中心用自己的私鑰,對頒發的公鑰和一些相關信息一起加密,生成"數字證書"(Digital Certificate)

證書鏈

Web 瀏覽器已預先配置了一組瀏覽器自動信任的根 CA 證書。
來自其他證書授權機構的所有證書都必須附帶證書鏈,以檢驗這些證書的有效性。
證書鏈是由一系列 CA 證書發出的證書序列,最終以根 CA 證書結束。

根證書

CA用自己的私鑰為公鑰簽名,用於驗證自己的公鑰

根證書是一份特殊的證書,它的簽發者是它本身,下載根證書就表明對該根證書以下所簽發的證書都表示信任

證書請求過程

  1. 生成非對稱加密的公鑰和私鑰
  2. 生成證書請求文件 (csr: CertificateSigningRequest),其中包含公鑰和與用戶信息
  3. 在 CA 網站上傳CSR文件
  4. CA 使用其 private key 對 CSR 中的 public key 和身份信息進行加密簽名生成數字證書(Digital Certificate)並保存
  5. 從 CA 網站下載證書並安裝

數字簽名

數位簽名不是指將簽名掃描成數字圖像,或者用觸摸板獲取的簽名,更不是落款。

將數據按約定的HASH演算法計算得到一個固定位數的摘要並用私鑰加密

image

證書和簽名的應用

image

證書在iOS開發中的應用

  • development

    • iOS App development

    • Apple Push Notification service SSL(Sandbox)

  • Production

    • App Store and Ad Hoc

    • Apple Push Notification service SSL(Sandbox & Production)

    • Pass Type ID Certificate

Provisioning Profiles

包含:
  • APP ID
  • 證書
  • Device UUID

作用

資料

https://developer.apple.com/library/ios/documentation/IDEs/Conceptual/AppDistributionGuide/MaintainingCertificates/MaintainingCertificates.html

https://developer.apple.com/library/ios/documentation/IDEs/Conceptual/AppDistributionGuide/Introduction/Introduction.html#//apple_ref/doc/uid/TP40012582-CH1-SW1

http://blog.csdn.net/holydancer/article/details/9219333

image


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 前言:由於最近在做SDK的功能,需要設計線程池。看了很多資料不知道從何開始著手,突然發現了AsyncTask有對線程池的封裝,so,就拿它開刀,本文將從AsyncTask的基本用法,到簡單的封裝,再到任務隊列分析,最後自定義線程池。 1、概念 Android 中的非同步任務常用的一種方式是:Handl ...
  • 因項目介面變動,導致之前的CoreData欄位需要調整。於是記錄下出錯的流程和解決方案。步驟如下: 1. 先在 *****.xcdatamodeld 文件中添加需要調整的欄位。並更新本地model實體。 2. 我的流程是接到消息後本地存儲在CoreData裡面,然後UI展示(具體消息推送和接收問題, ...
  • 參考文檔: http://cache.baiducontent.com/c?m=9f65cb4a8c8507ed4fece763105392230e54f73e7e808c027fa2ce0ac4384c413037bee43a7c4b54ce81273044b2141ebdac3574310023 ...
  • 一,代碼。 - (void)viewDidLoad { [super viewDidLoad]; // Do any additional setup after loading the view. self.title=@"字元串的分割"; //一般的字元串的解析 NSString *string ...
  • 一、何謂版本控制 它是一種軟體工程籍以在開發的過程中,確保由不同人所編輯的同一檔案都得到更新,它透過文檔控制記錄程式各個模塊的改動,併為每次改動編上序號,並且編輯錯誤之後還可以回溯到以前的版本 二、可供我們選擇的版本控制系統 1、VCS (本地版本控制) 2、VSS、CVS(集中版本控制) 3、Cl ...
  • 之前發表過一篇關於視錯覺的文章:《視錯覺:從一個看似簡單的自定義控制項說起》,雖然不是用iOS開發中的Mask來實現的,但是原理和Mask原理是一樣的,相當於手動給上面一層加了個Mask。當然用mask完全可以實現上篇博客中的效果,無論是使用Mask還是不使用Mask,都是利用了視錯覺,都是兩層不一樣 ...
  • Swift - UITableView展開縮放動畫 效果 源碼 https://github.com/YouXianMing/Swift-Animations ...
  • AndroidStudio(以後都簡稱AS),作為google的親兒子,終於出了個像樣的android ide,再也不用在eclipse中又是Adt,又是這又是那的,一大堆的集成了。廢話不多說,這個系列打算用AS+WebApi寫一個自己的Oa App(AS編寫App代碼,WebApi編寫介面代碼)。 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...