2017-11-25 37 views
1

我試圖用iOS的關聯應用程序擴展來構建Xamarin Forms應用程序。我的解決方案的結構是這樣的:Xamarin.iOS應用程序在丟失Mono運行時時崩潰;找不到合適的圖像;代碼簽名被阻止的mmap

MyProject 
    \BitThicket.MyProject     -- Forms project 
    \BitThicket.MyProject.Core    -- NET Standard 2.0 class library 
    \BitThicket.MyProject.iOS    -- iOS project 
    \BitThicket.MyProject.Extensions.Intents -- Intents project 

每個項目從模板創建的,我做了一些變化 - 和崩潰發生在啓動,因此沒有達到我的代碼反正。

我針對iOS 11.1,並且設置了有效的簽名證書和配置文件。我能夠構建應用程序並從Visual Studio for Mac(7.2.2)將它部署到設備(我的iPhone 7+)。但是,當調試器嘗試爲我啓動應用程序時,顯示空白的初始視圖,然後應用程序崩潰。調試器從不連接。順便說一句,當應用程序在設備上手動啓動時,它會以同樣的方式崩潰。

我檢索使用Xcode中設備日誌和崩潰是這樣的:

Incident Identifier: 948709A2-74AA-4E16-BEEA-072CFCF4AB38 
CrashReporter Key: ###################################### 
Hardware Model:  iPhone9,2 
Process:    BitThicket.Turns.iOS [2457] 
Path:    /private/var/containers/Bundle/Application/#####-##############-############/BitThicket.Turns.iOS.app/BitThicket.Turns.iOS 
Identifier:   com.bitthicket.Turns 
Version:    1.0 (1.0) 
Code Type:   ARM-64 (Native) 
Role:    Foreground 
Parent Process:  launchd [1] 
Coalition:   com.bitthicket.Turns [818] 


Date/Time:   2017-11-24 09:41:15.3743 -0600 
Launch Time:   2017-11-24 09:41:15.3041 -0600 
OS Version:   iPhone OS 11.1.2 (15B202) 
Baseband Version: 3.21.01 
Report Version:  104 

Exception Type: EXC_CRASH (SIGABRT) 
Exception Codes: 0x0000000000000000, 0x0000000000000000 
Exception Note: EXC_CORPSE_NOTIFY 
Termination Description: DYLD, Library not loaded: @rpath/Mono.framework/Mono | Referenced from: /var/containers/Bundle/Application/########-####-####-####-############/BitThicket.Turns.iOS.app/BitThicket.Turns.iOS | Reason: no suitable image found. Did find: | /private/var/containers/Bundle/Application/########-####-####-####-############/BitThicket.Turns.iOS.app/Frameworks/Mono.framework/Mono: code signing blocked mmap() of '/private/var/containers/Bundle/Application/########-####-####-####-############/BitThicket.Turns.iOS.app/Frameworks/Mono.framework/Mono' 
Triggered by Thread: 0 

Filtered syslog: 
None found 

Thread 0 Crashed: 
0 dyld       0x0000000106722f1c __abort_with_payload + 8 
1 dyld       0x00000001067226f4 abort_with_payload_wrapper_internal + 100 
2 dyld       0x0000000106722720 fcntl + 0 
3 dyld       0x00000001066f8498 dyld::fastBindLazySymbol+ 17560 (ImageLoader**, unsigned long) + 0 
4 dyld       0x00000001066fb714 dyld::_main+ 30484 (macho_header const*, unsigned long, int, char const**, char const**, char const**, unsigned long*) + 7376 
5 dyld       0x00000001066f521c _dyld_start + 68 

Thread 0 crashed with ARM Thread State (64-bit): 
    x0: 0x0000000000000006 x1: 0x0000000000000001 x2: 0x000000016d50a470 x3: 0x00000000000000a5 
    x4: 0x000000016d50a070 x5: 0x0000000000000000 x6: 0x0000000000000000 x7: 0x00000000000002f0 
    x8: 0x0000000000000020 x9: 0x0000000000000009 x10: 0x6f6e6f4d2f736b72 x11: 0x6f77656d6172662e 
    x12: 0x726f77656d617246 x13: 0x2e6f6e6f4d2f736b x14: 0x726f77656d617266 x15: 0x00276f6e6f4d2f6b 
    x16: 0x0000000000000209 x17: 0x000000008000001f x18: 0x0000000000000000 x19: 0x0000000000000000 
    x20: 0x000000016d50a070 x21: 0x00000000000000a5 x22: 0x000000016d50a470 x23: 0x0000000000000001 
    x24: 0x0000000000000006 x25: 0x00000001028f4000 x26: 0x0000000106736000 x27: 0x0000000106735f88 
    x28: 0x000000016d50ba70 fp: 0x000000016d50a040 lr: 0x00000001067226f4 
    sp: 0x000000016d50a000 pc: 0x0000000106722f1c cpsr: 0x00000000 

Binary Images: 
0x1028f4000 - 0x103e43fff BitThicket.Turns.iOS arm64 <###########################> /var/containers/Bundle/Application/########-####-####-####-############/BitThicket.Turns.iOS.app/BitThicket.Turns.iOS 
0x1066f4000 - 0x106733fff dyld arm64 <##########################> /usr/lib/dyld 

EOF 

有誰知道是什麼原因造成的?在Xamarin論壇或其他地方似乎沒有很多直接的答案(包括SO,不幸)。我已經嘗試了一些簡單的東西,比如重新啓動Visual Studio for Mac,或者從我的設備中刪除應用程序並清理/重建解決方案,但這些東西似乎沒有幫助。

在終止描述中,它聽起來像試圖加載單聲道,但mmap被代碼簽名以某種方式阻止 - 但我真的不知道如何。該應用程序構建並部署到我的設備,所以它看起來像代碼簽名正在工作。

回答

1

經過深入挖掘,我發現了幾個似乎相似的問題示例,最常見的方法似乎是簽名證書配置不正確。我仍然對其根本原因感到好奇 - 爲什麼背後是「爲什麼」。最終,我發現我在「系統」「登錄」鑰匙鏈上都有「Apple全球開發者關係證書頒發機構」,並且在「應始終信任」時配置爲「始終信任」只在我的「登錄」鑰匙串中進行配置,並配置爲「系統默認值」。

一旦我糾正了這些問題,我又試了一次,但仍然遇到了問題。它在重新啓動我的Mac之後終於消失了。

+0

感謝你們這樣做,這發生在我對我的應用程序使用自動簽名後,重新啓動(並且乾淨,雖然不確定如果需要)做了生意! :) – WickedW

相關問題