成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

iOS 9 適配系列教程

移動開發(fā)
iOS9把所有的http請求都改為https了:iOS9系統(tǒng)發(fā)送的網絡請求將統(tǒng)一使用TLS 1.2 SSL。采用TLS 1.2 協(xié)議,目的是 強制增強數據訪問安全,而且 系統(tǒng) Foundation 框架下的相關網絡請求,將不再默認使用 Http 等不安全的網絡協(xié)議,而默認采用 TLS 1.2。服務器因此需要更新,以解析相關數據。如不更新,可通過在 Info.plist 中聲明,倒退回不安全的網絡請求。

  本文是投稿文章,作者:ChenYilong(https://github.com/ChenYilong/iOS9AdaptationTips

 

Demo1_iOS9網絡適配_改用更安全的HTTPS

iOS9把所有的http請求都改為https了:iOS9系統(tǒng)發(fā)送的網絡請求將統(tǒng)一使用TLS 1.2 SSL。采用TLS 1.2 協(xié)議,目的是 強制增強數據訪問安全,而且 系統(tǒng) Foundation 框架下的相關網絡請求,將不再默認使用 Http 等不安全的網絡協(xié)議,而默認采用 TLS 1.2。服務器因此需要更新,以解析相關數據。如不更新,可通過在 Info.plist 中聲明,倒退回不安全的網絡請求。

在討論之前,跟往常一樣,先說下iOS程序猿們最關心的問題:

跟我有毛關系?需要我加班嗎?!

首先咱們來看下業(yè)內對Apple這一做法的評論:

1.jpg

這是某社交App上討論,看來業(yè)內還是吐槽聲和肯定聲同在。

結論是:

跟你很有關系,加班吧,少年!

書歸正傳【嚴肅臉】,我們正式討論下 WHAT,WHY,HOW:

  1. WHAT(什么是SSL/TLS?跟HTTP和HTTPS有什么關系)

  2. WHY(以前的HTTP不是也能用嗎?為什么要用SSL/TLS,閑得慌?!Apple是不是又在反人類?)

  3. HOW(如何適配?---弱弱地問下:加班要多久?)

WHAT(什么是SSL/TLS?跟HTTP和HTTPS有什么關系)

跟往常一樣,先說結論:

  1. HTTP+SSL/TLS+TCP = HTTPS 

TLS 是 SSL 新的別稱。舉個例子:

“TLS1.0”之于“SSL3.1”,猶“公元2015”之于“民國104”,或者是“一千克”之于“一公斤”,或者是“半斤”之于“八兩”:稱呼不同,但意思相同。

SSL 3.0版本之后的迭代版本被重新命名為TLS 1.0,

也就是說:

  1. TLS 1.0 = SSL 3.1 

所以他們是一個東西,我們平常也經常簡單見到 “SSL/TLS” 這種說法。

常用的是下面這些:

  • SSL 2.0

  • SSL 3.0

  • TLS 1.0 (SSL 3.1)

  • TLS 1.1 (SSL 3.1)

  • TLS 1.2 (SSL 3.1)

那為什么標題是“使用HTTPS”而沒有提及SSL和TLS什么事? 要理解這個,要看下一個公式:

  1. HTTP+SSL/TLS+TCP = HTTPS 

blob.png

打個比方:如果原來的 HTTP 是塑料水管,容易被戳破;那么如今新設計的 HTTPS 就像是在原有的塑料水管之外,再包一層金屬水管。一來,原有的塑料水管照樣運行;二來,用金屬加固了之后,不容易被戳破。

目前,應用最廣泛的是TLS 1.0,接下來是SSL 3.0。但是,主流瀏覽器都已經實現了TLS 1.2的支持。

Apple讓你的HTTP采用SSL/TLS協(xié)議,就是讓你從HTTP轉到HTTPS

#p#

WHY(以前的HTTP不是也能用嗎?為什么要用SSL/TLS,閑得慌?!Apple是不是又在反人類?)

不使用SSL/TLS的HTTP通信,就是不加密的通信!

所有信息明文傳播,帶來了三大風險:

  1. 竊聽風險(eavesdropping):第三方可以獲知通信內容。

  2. 篡改風險(tampering):第三方可以修改通信內容。

  3. 冒充風險(pretending):第三方可以冒充他人身份參與通信。

SSL/TLS協(xié)議是為了解決這三大風險而設計的,希望達到:

  1. 所有信息都是加密傳播,第三方無法竊聽。

  2. 具有校驗機制,一旦被篡改,通信雙方會立刻發(fā)現。

  3. 配備身份證書,防止身份被冒充。

HOW(如何適配?---弱弱地問下:加班要多久?)

正如文章開頭所說:

TLS 1.2 協(xié)議 強制增強數據訪問安全 系統(tǒng) Foundation 框架下的相關網絡請求,將不再默認使用 Http 等不安全的網絡協(xié)議,而默認采用 TLS 1.2。服務器因此需要更新,以解析相關數據。如不更新,可通過在 Info.plist 中聲明,倒退回不安全的網絡請求。

方案一:立即讓公司的服務端升級使用TLS 1.2

方案二:雖Apple不建議,但可通過在 Info.plist 中聲明,倒退回不安全的網絡請求依然能讓App訪問指定http,甚至任意的http,

具體做法見gif圖,示例Demo見 Demo1

2.gif

正如 Apple官方文檔 所說 :

blob.png

blob.png

blob.png

Info.plist 配置中的XML源碼如下所示:

645.jpg

上面是比較嚴謹的做法,指定了能訪問哪些特定的HTTP。當然也有暴力的做法: 徹底倒退回不安全的HTTP網絡請求,能任意進行HTTP請求,比如你在開發(fā)一款瀏覽器App,或者你想偷懶,或者后臺想偷懶,或者公司不給你升級服務器。。。

646.jpg

聲明:目前Apple的官方文檔并未提及如何在 Info.plist 配置,我將密切關注官方文檔,如有提及,再來更新本文 。

#p#

 

Demo2_iOS9新特性_更靈活的后臺定位

0.jpg

Demo:GitHub地址

【iOS9在定位的問題上,有一個壞消息一個好消息】壞消息:如果不適配iOS9,就不能偷偷在后臺定位(不帶藍條,見圖)!好消息:將允許出現這種場景:同一App中的多個location manager:一些只能在前臺定位,另一些可在后臺定位,并可隨時開啟或者關閉特定location manager的后臺定位。

如果沒有請求后臺定位的權限,也是可以在后臺定位的,不過會帶藍條:

1.jpg

如何偷偷在后臺定位:請求后臺定位權限:

 
  1.  // 1. 實例化定位管理器 
  2. _locationManager = [[CLLocationManager alloc] init]; 
  3. // 2. 設置代理 
  4. _locationManager.delegate = self; 
  5. // 3. 定位精度 
  6. [_locationManager setDesiredAccuracy:kCLLocationAccuracyBest]; 
  7. // 4.請求用戶權限:分為:?只在前臺開啟定位?在后臺也可定位, 
  8. //注意:建議只請求?和?中的一個,如果兩個權限都需要,只請求?即可, 
  9. //??這樣的順序,將導致bug:第一次啟動程序后,系統(tǒng)將只請求?的權限,?的權限系統(tǒng)不會請求,只會在下一次啟動應用時請求? 
  10. if ([[[UIDevice currentDevice] systemVersion] floatValue] >= 8) { 
  11.     //[_locationManager requestWhenInUseAuthorization];//?只在前臺開啟定位 
  12.     [_locationManager requestAlwaysAuthorization];//?在后臺也可定位 
  13. // 5.iOS9新特性:將允許出現這種場景:同一app中多個location manager:一些只能在前臺定位,另一些可在后臺定位(并可隨時禁止其后臺定位)。 
  14. if ([[[UIDevice currentDevice] systemVersion] floatValue] >= 9) { 
  15.     _locationManager.allowsBackgroundLocationUpdates = YES; 
  16. // 6. 更新用戶位置 
  17. [_locationManager startUpdatingLocation]; 

但是如果照著這種方式嘗試,而沒有配置Info.plist,100%你的程序會崩潰掉,并報錯:

 
  1. *** Assertion failure in -[CLLocationManager setAllowsBackgroundLocationUpdates:], 
  2. /BuildRoot/Library/Caches/com.apple.xbs/Sources/CoreLocationFramework_Sim/CoreLocation-1808.1.5/
  3. Framework/CoreLocation/CLLocationManager.m:593 

要將 Info.plist 配置如下:

blob.png

對應的 Info.plist 的XML源碼是:

blob.png

Bitcode(通俗解釋:在線版安卓ART模式)

未來Watch應用須包含Bitcode,iOS不強制,但Xcode7默認會開啟Bitcode。

如何適配?

方法一:更新library使包含Bitcode,否則會出現以下中的警告;

  1. (null): URGENT: all bitcode will be dropped because '/Users/myname/Library/
  2. Mobile Documents/com~apple~CloudDocs/foldername/appname/GoogleMobileAds.framework/
  3. GoogleMobileAds(GADSlot+AdEvents.o)' was built without bitcode. 
  4. You must rebuild it with bitcode enabled (Xcode setting ENABLE_BITCODE), 
  5. obtain an updated library from the vendor, or disable bitcode for this target. 
  6. Note: This will be an error in the future. 
方法二:關閉Bitcode,方法見下圖

1.gif

更多信息,請移步 bitcode 蘋果官方文檔,和 WWDC 2015 Session 102: "Platforms State of the Union"

[[140110]]

#p#

企業(yè)級分發(fā)

iOS9之前,企業(yè)級分發(fā)十分方便:點擊App出現“信任按鈕”,

1.jpg

iOS9以后,企業(yè)級分發(fā)ipa包將遭到與Mac上dmg安裝包一樣的待遇:默認不能安裝,也不再出現“信任按鈕”

2.jpg

必須讓用戶進行gif圖中的設置(相關Demo:https://github.com/ChenYilong/iOS9AdaptationTips/ )

3.gif

URL scheme

在iOS9中,如果使用URL scheme必須在"Info.plist"中將你要在外部調用的URL scheme列為白名單,否則不能使用。key叫做LSApplicationQueriesSchemes ,鍵值內容是

  1. LSApplicationQueriesSchemes urlscheme urlscheme2 urlscheme3 urlscheme4 

推薦一篇博客: http://awkwardhare.com/post/121196006730/quick-take-on-ios-9-url-scheme-changes

其中最關鍵的是以下部分:

  1. If you call the “canOpenURL” method on a URL that is not in your whitelist,
  2.  it will return “NO”, even if there is an app installed that has registered to handle this scheme.
  3.  A “This app is not allowed to query for scheme xxx” syslog entry will appear. 
  4. If you call the “openURL” method on a URL that is not in your whitelist, it will fail silently. 
  5. A “This app is not allowed to query for scheme xxx” syslog entry will appear. 

更多信息請移步:WWDC 2015 Session 703: "Privacy and Your App" 時間在30:18左右

blob.png

iPad適配Slide Over 和 Split View

1.gif

【iPad適配Slide Over 和 Split View】 若想適配multi tasking特性,唯一的建議:棄純代碼,改用storyboard、xib,縱觀蘋果WWDC所有Demo均是如此:

  1. Mysteries of Auto Layout, Part 1

  2. What's New in Storyboards

  3. Implementing UI Designs in Interface Builder

  4. Getting Started with Multitasking on iPad in iOS 9

  5. Optimizing Your App for Multitasking on iPad in iOS

 

責任編輯:倪明
相關推薦

2015-06-24 10:06:09

iOS 9適配后臺

2015-09-23 10:30:44

iOS 9UIStack Vie

2015-09-16 09:55:12

ios9學習UIKit Dynam

2015-08-20 09:00:23

ios9api

2015-08-24 09:24:21

ios學習contacts fr

2015-09-25 09:44:24

ios9MapkitTrans

2015-10-12 11:26:12

iOS 9適配

2016-03-18 11:19:57

ios9replaykit入門

2015-08-24 09:19:05

ios9split scree

2017-11-10 13:02:44

iOSUI代碼

2015-07-02 16:25:09

iOS 9UIStackView

2020-10-25 08:56:21

適配器模式

2015-08-20 09:19:46

ios9uistackview

2013-11-26 16:39:21

Android設計模式

2021-02-18 08:39:28

設計模式場景

2013-12-17 16:21:17

iOSiOS性能優(yōu)化

2015-09-28 11:23:09

iOS8iOS 9 開發(fā)

2013-07-23 07:34:54

iOS開發(fā)學習適配iphone5

2016-10-12 10:32:54

ios10siriqq

2013-06-18 02:39:29

CocoStudio工Cocos2d-x
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 91超碰在线| 国产精品国产三级国产aⅴ无密码 | 国产激情在线 | 日韩欧美精品一区 | 亚洲精品久久久一区二区三区 | 欧美国产精品一区二区三区 | 国产美女一区 | 一级做a爰片性色毛片视频停止 | 国产精品视频网站 | 日韩电影免费在线观看中文字幕 | 国产成人精品综合 | 天天射天天操天天干 | 国产精品一区二区久久精品爱微奶 | 91久久精品日日躁夜夜躁国产 | 中文字幕在线观看一区 | 欧美一区二区三区在线观看视频 | 四虎在线观看 | 免费亚洲视频 | 青草久久免费视频 | 国产欧美精品区一区二区三区 | 欧美三级在线 | 成人欧美| 91久久久久久久久久久 | 亚洲精品一区二区三区在线观看 | 久夜精品 | 亚洲一区在线日韩在线深爱 | 自拍偷拍亚洲欧美 | 久久av资源网 | 国产电影一区二区在线观看 | 99热碰 | 中文字幕在线观看视频一区 | 成人自拍视频网站 | 久久伦理中文字幕 | 国产免费一区二区三区网站免费 | 国产乱码精品一区二区三区中文 | 欧美精品乱码99久久影院 | 成人三级视频在线观看 | 久久一视频 | 久久久久久久久中文字幕 | 国产污视频在线 | 成人黄色电影在线观看 |