1、MFi 認證
1.1 什么是 MFi 認證
-
蘋果 MFi 認證,是蘋果公司(Apple Inc.)對其授權配件廠商生產的外置配件的一種標識使用許可,是 Apple 公司 “Made for iOS” 的英文縮寫。
-
市面上認證產品的顯著標識就是在包裝正面出現如下白底黑字的蘋果 MFi 授權 logo,如本文開頭圖片所示。蘋果公司允許授權廠商在產品包裝上印上授權標簽。有句話叫無商不奸,如果消費者擔心生產商作假,未授權的硬件也偷偷貼上 MFi 的授權標簽,那么可以登錄蘋果的官方網站,進行查詢。如下圖
1.2 為什么要做 MFi 認證
-
從蘋果角度來看,為了更好的鞏固蘋果的生態圈,只有集成了有 MFi 芯片,才能跟 iPhone、iPod,iPad 進行連接通信。而只有經過了 MFi 認證的企業才能批量購買 MFi 芯片,並且 MFi 芯片的供銷鏈條都有很嚴格的監督管理,所以這樣蘋果可以嚴格控制只有那些滿足蘋果規范和要求的外設才能加入到蘋果生態圈。
-
從生產廠商來看,經過蘋果官方授權,配件產品能完美兼容蘋果智能設備;提交 MFi 認證過程中,硬件設備需要經過蘋果要求的 ATS 自測以及蘋果的嚴格測試,產品質量更有保證;消費者也更加信任經過了 MFi 認證授權的配件;最后成功獲得 MFi 授權這也成為技術與質量實力的一種標志,因為 MFi 認證通過率僅 2%,其中大部分企業因為申請資格不符合直接被拒絕。
-
從 iOS 開發人員來看,MFi 認證是由硬件生產商主導進行申請的,是蘋果對外設配件的一種認證和授權。但是很多外設跟蘋果進行連接,並不只是跟 iOS 設備硬件或者 iOS 系統配合就可以完成對應的功能(比如充電、CarPlay、播放 iPod 音樂(A2DP)、接聽藍牙電話(HPF)或者提供 GPS 輸入源等)。很多時候為了實現特定的需求,需要由 iOS App 的配合,由 iOS App 跟對應外設進行連接和通信,傳輸相關的控制命令對外設進行控制,或者傳輸相關的外設數據進行展示。iOS App 跟外設的連接方式有網絡、EAP 和 BLE,其中 EAP 是蘋果官方推薦的跟外設連接的方式。只有經過 MFi 認證的外設才能使用 EAP 跟 App 進行通信。
1.3 如何做 MFi 認證
-
MFi 認證的流程比較復雜,可以歸納總結為三個部分,如下圖所示
-
其中黃色背景標注的部分是可能跟 iOS App 開發者相關的。其他部分則都是由硬件生產商主導進行的,作為 iOS 開發人員並不需要參與。
-
1、申請人提交申請資料
-
首先,收集公司資料信息,這些資料主要包括了認證負責人聯系信息,企業情況介紹,公司組織架構、企業網站,物料品質控制以及 ISO 體系證書等資料。然后是在蘋果 MFi 官網 上進行注冊,並提交第一步收集到的公司資料,進行賬號申請。
-
接下來蘋果會進行 MFi 體系審核。這個是非常關鍵的一個步驟。主要考察公司對 MFi 芯片的管理體系,看公司是否有規范的流程和系統來管理 MFi 芯片,能有效防止轉售芯片或者挪用芯片(把芯片用到未通過 MFi 認知的項目上),蘋果會安排專人或者代理公司來抽查。
-
如果 MFi 體系審核過了,蘋果還會對公司其他情況進行考察,來評估該公司是否滿足 MFi 會員的資格。審核的標准主要看公司相關資質,是否有較大的生產規模;是否擁有自主品牌;品牌在業內是否有較高的地位(主要表現為各類榮譽);是否曾為其他國際知名企業供貨;研發人員是否達到蘋果要求的人數等,申請者一定保證申報資料的真實性,蘋果公司都會一一核實。
-
如果這些條件都滿足,恭喜你公司成為了 MFi 會員,能夠有資格購買樣品芯片,並且拿到蘋果提供的 MFi 官方開發文檔,該文檔的每一頁都是帶有申請人姓名水印的,禁止對外公開,如果被發現,有可能會被取消 MFi 會員資格。據說大部分的企業都會被卡在會員資格審核這一步。
-
-
2、提交產品計划,研發和自測
-
如果你的公司是屬於那幸運的那一小部分通過了 MFi 會員資格審核,拿到了蘋果的 MFi 研發官方文檔,也購買了 MFi 樣品芯片,那么就可以提交產品計划,進行產品研發和自測了。
-
提交產品計划是非常關鍵的一步,需要根據要研發的公司產品的形態、所用技術方案和需要支持的 iOS 設備、iOS 的相關信息都進行詳細的描述,其中比較重要信息有。
-
1)附件概覽(Accessory Overview)
- 技術方案(Technology)如果你是做支持 CapPlay 的車機,那么就選擇 CarPlay,否則都應該選擇 iAP;如果你的硬件需要跟 iPhone 連接,並且處理相關業務,而不僅僅是充電線或者數據線,那么在 Components 里應該選擇 Authentication coprocessor.
-
2)固件和硬件(Firmware & Hardware)
- 現在所有的 MFi 認證的硬件都需要支持 iAP2 協議,所以必須要選 iAP2 或者同時支持 iAP2 和 iAP1。然后外設硬件跟蘋果設備是如何通信的,是使用 USB 的 Host 模式,還 USB 的 Devices 模式,還是串口或者藍牙,這個需要根據產品的需求、特性進行選擇。
-
3)選擇硬件所支持的 iAP2 的特性
-
4)選擇所支持的蘋果設備型號。
- 根據產品的設計選擇所需要支持的蘋果設備型號,包括 iPad,iPhone 和 iPod 的各種型號。
-
5)App 相關的信息
- 這部分也是 iOS 開發者需要重點關注的部分,包括 App 的版本號,BundleID 和協議字符串以及 iOS App 的主要功能特性描述,這部分信息需要跟最后送 MFi 審核時附帶的 App 測試包的信息保持一致。提交了產品計划之后,就可以拿到 PPID(Product Plan ID)。這個 PPID 也是跟 iOS App 開發者需要關注的。當 App 開發完成,提交 AppStore 上線時,需要在版本審核備注信息里帶上這個 PPID,否則審核是過不了的。
-
接下來就可以進行產品研發了。主要是硬件生成商需要根據蘋果提供的開發文檔進行硬件和驅動認證程序的開發。而 iOS App 開發者則主要是需要集成 iOS 系統提供的一個系統框架 ExternalAccessory.framework,並且在 info.plist 中配置好協議字符串(Supported external accessory protocols)。當 iOS 設備通過 USB 線或者藍牙連接到對應硬件時,iOS 系統會把符合 MFi 認證要求的外設抽象成了一個流對象,App 通過指定的協議字符串來創建一個 EASession 類的實例來訪問到該流對象,就能通過 NSInputStream 和 NSOutputStream 跟硬件件進行通信了。這部分功能實現可以參考蘋果官方的 EADemo 進行入門和學習。
-
產品研發完成后需要進行 ATS(Accessory Test System)自測,並提供自測報告。ATS 自測蘋果會提供 ATS Box 的測試工具和軟件,主要是針對硬件進行電氣特性相關的測試,包括各個節點的電壓電流值是否滿足蘋果要求,然后傳輸帶寬是否穩定,是否達到蘋果要求等等。
-
自測完成之后就可以把硬件和所配套的軟件(iOS App 的 ipa 安裝包)送到蘋果指定的測試實驗室進行認證測試。iOS 開發者在這個步驟需要關注的是如何打包 ipa 包。因為如果直接用開發證書打包,那么蘋果測試人員的 iPhone 不在你開發證書的設備列表中,是無法安裝的。如果用企業證書打包的話,可能 AppStore 發布證書對應的 bundleid 跟企業證書的 bundleid 不一致,所以也不可行。所以推薦的做法是,等到產品研發完成和自測之后,就帶上產品計划中拿到的 PPID,提交 AppStore 進行審核。等審核通過之后,就可以直接從 AppStore 下載對應的 ipa 安裝包,配合硬件一起送 MFi 認證測試了。
-
-
3、測試審核和批量生產
-
這個階段也是硬件生產商主導進行的,跟 iOS app 開發者關系不大。當硬件的 MFi 認證送審通過之后,還需要對產品的包裝也提交認證和審核。審核通過之后,就可以獲得蘋果授權進行 MFi 芯片的批量購買,然后根據銷售計划進行硬件的批量生產和銷售了。
-
整個 MFi 認證的周期大概需要 3 個月到半年的時間,並且每次提交認證測試都需要支付一筆 600 美金的測試費用,所寄去測試的硬件測試樣品蘋果也是不會寄回來的。
-
2、NCM 將只能用於 CarPlay
-
最近 MFi 開發的蘋果官方文檔更新到 R25(《Accessory Interface Specification R25.pdf》)了,相比之前的版本,在 CarPlay 的章節中多了這樣一句話 “Accessories must not use the NCM interface for anything other than CarPlay”,如下圖所示:
-
這意味着什么呢? 意味着除了 CarPlay,后面所有其他跟 iPhone 連接的外設都不能使用 NCM 的方式跟 iPhone 上的 App 進行連接和通信了。NCM 只能用於 CarPlay,否則外設將無法通過 MFi 認證。
-
如果你的外設是采用的 NCM 方式跟 App 進行通信,並且目前還沒有通過 MFi 認證,需要盡快調整方案,建議改成 EAP(External Accessory Protocol)連接方式,這個是蘋果官方推薦連接方式。否則,肯定是過不了 MFi 認證的。
-
如果你的外設采用的 NCM 方式跟 App 進行通信,並且已經經過了 MFi 認證。那么可以保持現狀,不用擔心。有人會說蘋果會不會后面升級 iOS 系統時,在某個版本中直接在系統底層做限制,如果不是 CarPlay 模式就不能切出 NCM 的端口? 這種擔心,小編認為是多余的,因為蘋果也是最新的 Spec 才加入這種限制,意味着之前肯定有很多外設采用 NCM 並且通過了蘋果的 MFi 認證,蘋果需要保證 iPhone 升級 iOS 系統后也能兼容以前的外設。
-
NCM 按理說是一種非常標准的 USB 傳輸方式,它把 USB 端口虛擬成標准的網絡端口,具有帶寬高、天然支持多通道等優點,那蘋果為什么要做出這種限制呢?小編猜測還是跟蘋果想要嚴格把控 iOS 系統生態有關。
-
因為如果采用 EAP,那么對應的 App 就必須集成蘋果的 EA 框架(ExternalAccessory.framework),提交 AppStore 審核時,AppStore 通過代碼掃描就能掃描到 App 使用到了 EA 框架,知道該 App 需要跟外設進行通信,就需要 App 必須提供對應外設的 PPID(Product Plan ID),如果不能提供 PPID 就會被 AppStore 拒絕。這樣就能更嚴格控制 iOS 系統生態,外設和對應的 App 都在蘋果的控制范圍之內。
-
如果 App 采用 NCM 的方式跟外設通信,在 App 層面來說 NCM 就是標准的網絡通信,使用 TCP/IP 協議。App 提交 AppStore 審核時,如果不明說這個 App 可以連接某種 MFi 外設,蘋果是完全不知道的,這樣蘋果就在一定程度上丟失對 App 的把控。