Sandbox App使用第三方Binary文件

所謂sandbox App是指那些為了發布到App Store的,受到權限控制的App。一般Sandbox App擁有如下權限

Paste_Image.png

一波三折 之一

項目需要我們在符合Sandbox權限約束下的App中使用第三方的一個開源項目的Binary。并在之中調用這個Binary以進行一些功能上的實現。

于是,我興高采烈地直接拿到了local build版本的這個Binary,以下簡稱N文件。我通過包一個帶UI的Sandbox App的方式,通過NSTask調用了這個Binary,一切功能運行正常。
于是乎直接申請對應App ID,上傳之,準備發布。
然而,正以為一切都盡在掌控之際,陡生變故。在使用Xcode上傳時,連第一步的Validate都未通過。并且錯誤顯示我的這個N文件無Sandbox權限
經過研究,原來,在Sandbox下的可獨立執行的文件都必須符合Sandbox權限管控。可是,這是一個Command Line Tool的項目啊,這個如何加入Sandbox權限呢?

一波三折 之二

經過研究,發現可以通過

codesign --entitlements ./entitlements.plist -s "copy & paste your certificate from keychain" ./commandlinetool

來將我們手動創建的entitlements文件(記錄了app的sandbox權限信息)sign進對應的commondlinetool
請參考Stackoverflow原貼

以為一切就如此順利的搞定了。剛準備為自己的運氣而慶幸,直接運行,出現

Illegal instruction: 4

這是因為我們為一個原本不受權限控制的可執行文件強行添加權限之后無法執行。
再次研究,從Apple官方文檔中找到

Add the following arguments to your linker flags:
-sectcreate __TEXT __info_plist Info.plist_path

Info.plist 是記錄一個SandboxApp 相關Bundle信息的文件,我一拍腦袋。我只顧為一個Binary進行權限分配,而沒有為這個Binary包相關的Bundle信息,那么這個程序在運行時由于缺少Bundle信息,在Sandbox 化時系統無法為其生成相關的Container。根據文檔,我修改了Makefile,添加了Linkflag

一波三折 之三

折騰了一天,終于可以下班了吧。在Terminal中完美運行了這個Sandbox化的N文件之后,我把它重新包進了之前帶UI的Sandbox App。然而,運行后程序毫無反饋。調試后發現,既無報錯也無Console。因為正常如果有任何異常都會有Console報錯,如果能夠運行,Console中會有運行中的Log信息。

欲哭無淚,毫無頭緒。

經過多方求助終于在Apple的一個developer forum回帖中發現了一個相關回答
其中,有價值的兩點

1.Sandbox inheritance (com.apple.security.inherit)
2.converting your tool to some sort of script (a shell script, Python, whatever).

先嘗試了包一個shell,發現在Sandbox的app中調用bash去run 自己寫的shell,再通過這個shell去run我們的binary是不可行的,報錯:operation not permitted

再看第二點,查Apple 文檔和具體的這個com.apple.security.inherit權限文檔
深入研究后發現,

To enable sandbox inheritance, a child must use exactly two App Sandbox entitlement keys: com.apple.security.app-sandbox and com.apple.security.inherit. If you specify any other App Sandbox entitlement, the system aborts the child process. You can, however, confer other capabilities to a child process by way of iCloud and notification entitlements.

也就是說,我們的N文件現在是作為我們包的UI App的子項,于是我們需要讓這個N文件繼承UI App的Sandbox權限,而不是把它自己作為一個獨立的Sandbox App。
于是,

  1. 去掉Makefile中之前添加的linkflag
  2. 將entitlement文件改為

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">
<plist version="1.0">
<dict>
<key>com.apple.security.app-sandbox</key>
<true/>
<key>com.apple.security.inherit</key>
<true/>
</dict>
</plist>

重新make,然后codesign,并把新N文件包進去

黎明

終于,這個程序正常了,并且N文件和外包的UI App公用同樣的Bundle信息,同一個Container,使用同樣的Sandbox權限。

總結

整個過程一波三折,每當有進展之后以為圓滿解決了又來了更大的問題。同時,相關資料非常少,我全程查英文第一手資料,但是無奈Apple文檔目錄太深,Google也幫不了我。好在各種機緣和強大的同事,我們一步一步的猜想,實驗,破解了謎團。
App已經提交了,也許Apple不允許這樣的通過N文件的方式進行包裝,不過在這個過程中對Sandbox權限和項目構建有了更深的理解。

相關的中文資料基本沒有,希望能夠給同樣在坑中的人們帶來一些參考。

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市,隨后出現的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 227,401評論 6 531
  • 序言:濱河連續發生了三起死亡事件,死亡現場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機,發現死者居然都...
    沈念sama閱讀 98,011評論 3 413
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事。” “怎么了?”我有些...
    開封第一講書人閱讀 175,263評論 0 373
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經常有香客問我,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 62,543評論 1 307
  • 正文 為了忘掉前任,我火速辦了婚禮,結果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當我...
    茶點故事閱讀 71,323評論 6 404
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發上,一...
    開封第一講書人閱讀 54,874評論 1 321
  • 那天,我揣著相機與錄音,去河邊找鬼。 笑死,一個胖子當著我的面吹牛,可吹牛的內容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 42,968評論 3 439
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側響起,我...
    開封第一講書人閱讀 42,095評論 0 286
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后,有當地人在樹林里發現了一具尸體,經...
    沈念sama閱讀 48,605評論 1 331
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 40,551評論 3 354
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發現自己被綠了。 大學時的朋友給我發了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 42,720評論 1 369
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 38,242評論 5 355
  • 正文 年R本政府宣布,位于F島的核電站,受9級特大地震影響,放射性物質發生泄漏。R本人自食惡果不足惜,卻給世界環境...
    茶點故事閱讀 43,961評論 3 345
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 34,358評論 0 25
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春,著一層夾襖步出監牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 35,612評論 1 280
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個月前我還...
    沈念sama閱讀 51,330評論 3 390
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 47,690評論 2 370

推薦閱讀更多精彩內容

  • PLEASE READ THE FOLLOWING APPLE DEVELOPER PROGRAM LICENSE...
    念念不忘的閱讀 13,503評論 5 6
  • 如果你看完書中的所有例子,你很可能已經做完你的實驗和在已經越獄的iPhone上的研究。因為和許多人一樣,幾乎所有的...
    fishmai0閱讀 16,205評論 2 42
  • 36【學習】科學的重復事半功倍 如果我們去重復(復習),我們會記得更多。 艾賓浩斯記憶曲線: 分為8大周期是:5m...
    依盈閱讀 118評論 0 0
  • 1.海爾 智能化產品的研發制造基地,海爾集團在物聯網時代推出的美好住居生活解決方案,青島海爾智能家電科技有限公司 ...
    簡書小飛閱讀 1,300評論 0 0
  • 壹 “叮!” 凌晨一點多,我收到老師的郵件,神經質地一抖,差點打翻面前的酒杯。 “怎么了?”身邊朋友微微有些醉意,...
    韓半兩閱讀 347評論 0 1