2015-07-19 16 views
7

kontekścieZawieszenie w OpenURL: Możliwe Facebook SDK błąd w iOS 9

Używam FBSDKLoginButton z mojej aplikacji. Jestem na Xcode 7.0 i na moim iPhone'ie działa iOS 9 beta 3. Śledziłem każdy krok pokazany przez Facebooka (tworzenie aplikacji itp.) I postępowałem zgodnie z instrukcjami dodawania przycisku, jak w https://developers.facebook.com/docs/facebook-login/ios#login-button.

Ponieważ jestem na iOS 9, musiałem dodać kilka drobnych zmian do pliku info.plist włączyć cross-app otwarcia:

<key>LSApplicationQueriesSchemes</key> 
<array> 
    <string>fbauth</string> 
</array> 

a od metody z UIAppDelegateopenURL zmieniono na iOS9, Zmieniłem Kod openURL fragment Facebook zapewnia z tego:

func application(application: UIApplication, 
    openURL url: NSURL, 
    sourceApplication: String?, 
    annotation: AnyObject?) -> Bool { 
     return FBSDKApplicationDelegate.sharedInstance().application(
      application, 
      openURL: url, 
      sourceApplication: sourceApplication, 
      annotation: annotation) 
} 

do tego:

func application(app: UIApplication, openURL url: NSURL, options: [String : AnyObject]) -> Bool 
{ 
     return FBSDKApplicationDelegate.sharedInstance().application(
      app, 
      openURL: url, 
      sourceApplication: options["UIApplicationOpenURLOptionsSourceApplicationKey"] as? String, 
      annotation: nil) 
} 

Issue & Pytanie Więc mój problem jest to, że mimo wszystko działa doskonale (mam na myśli cały proces przycisk logowania plusa Pobieranie danych użytkowników z wykresu Facebook) kiedy uruchomić aplikację z symulatora lub bezpośrednio na moim iPhonie od XCode, I do mam problem, gdy uruchomię ten sam proces z moją aplikacją , ale tym razem zainstalowałem z archiwum. Próbowałem użyć aplikacji OTA lub aplikacji zainstalowanej wraz z organizerem Xcode przy użyciu pliku IPA archiwum. W obu przypadkach otrzymuję awarię , gdy Facebook wraca do mojej aplikacji. Ponieważ nie mogę używać debuggera Xcode, wszystko, co mam, to dziennik awarii.

Incident Identifier: 842E980C-8DE0-485F-8B3E-8CD889D34B3B 
CrashReporter Key: 3e77866746471e437b9174c6082fc9136a18514f 
Hardware Model:  iPhone7,2 
Process:    Process Name [1086] 
Path:    /private/var/mobile/Containers/Bundle/Application/AA43C098-DFC0-483C-A073-C2401078E9FC/Some App.app/someapp 
Identifier:   fr.someapp.Some-App 
Version:    1 (1.0) 
Code Type:   ARM-64 (Native) 
Parent Process:  launchd [1] 

Date/Time:   2015-07-19 20:18:41.41 +0200 
Launch Time:   2015-07-19 20:18:35.35 +0200 
OS Version:   iOS 9.0 (13A4293g) 
Report Version:  105 

Exception Type: EXC_BREAKPOINT (SIGTRAP) 
Exception Codes: 0x0000000000000001, 0x000000010005f6e4 
Triggered by Thread: 0 

Filtered syslog: 
None found 

Global Trace Buffer (reverse chronological seconds): 
0.228132  AppleJPEG     0x000000018dba5008 [0x13e871e00] Decoding completed without errors 
0.250546  AppleJPEG     0x000000018dba31a0 [0x13e871e00] Options: 1080x1920 [FFFFFFFF,FFFFFFFF] 00025060 
0.250629  AppleJPEG     0x000000018dba3058 [0x13e871e00] Decoding: C0 0x04380780 0x0044304A 0x22111100 0x00000000 175592 
0.256474  AppleJPEG     0x000000018dba5008 [0x13e867200] Decoding completed without errors 
0.261051  AppleJPEG     0x000000018dba31a0 [0x13e867200] Options: 750x1334 [FFFFFFFF,FFFFFFFF] 00025060 
0.261101  AppleJPEG     0x000000018dba3058 [0x13e867200] Decoding: C0 0x02EE0536 0x002F304A 0x22111100 0x00000000 75882 
0.262141  AppleJPEG     0x000000018dba5008 [0x13e85c600] Decoding completed without errors 
0.272075  AppleJPEG     0x000000018dba31a0 [0x13e85c600] Options: 750x1334 [FFFFFFFF,FFFFFFFF] 00025060 
0.272281  AppleJPEG     0x000000018dba3058 [0x13e85c600] Decoding: C0 0x02EE0536 0x002F304A 0x22111100 0x00000000 108826 
0.273070  AppleJPEG     0x000000018dba5008 [0x13f04bc00] Decoding completed without errors 
0.283798  AppleJPEG     0x000000018dba31a0 [0x13f04bc00] Options: 750x1334 [FFFFFFFF,FFFFFFFF] 00025060 
0.283798  AppleJPEG     0x000000018dba3058 [0x13f04bc00] Decoding: C0 0x02EE0536 0x002F304A 0x22111100 0x00000000 72967 
5.783070  CFNetwork     0x0000000186041d44 TCP Conn 0x13e5a1b90 SSL Handshake DONE 
5.874750  CFNetwork     0x0000000186041c54 TCP Conn 0x13e5a1b90 starting SSL negotiation 
5.875481  CFNetwork     0x00000001860e0e14 TCP Conn 0x13e5a1b90 complete. fd: 6, err: 0 
5.876954  CFNetwork     0x00000001860e21e4 TCP Conn 0x13e5a1b90 event 1. err: 0 
5.984181  CFNetwork     0x00000001860e22f8 TCP Conn 0x13e5a1b90 started 
5.992333  CFNetwork     0x0000000186137140 Creating default cookie storage with default identifier 
5.992333  CFNetwork     0x000000018613710c Faulting in CFHTTPCookieStorage singleton 
5.992562  CFNetwork     0x0000000186188068 Faulting in NSHTTPCookieStorage singleton 
6.189612  AppleJPEG     0x000000018dba234c [0x13e871e00] Created session 
6.190797  AppleJPEG     0x000000018dba234c [0x13e867200] Created session 
6.192109  AppleJPEG     0x000000018dba234c [0x13e85c600] Created session 
6.197484  AppleJPEG     0x000000018dba234c [0x13f04bc00] Created session 



Thread 0 name: Dispatch queue: com.apple.main-thread 
Thread 0 Crashed: 
0 Some app      0x000000010005f6e4 function signature specialization <Arg[0] = Owned To Guaranteed, Arg[1] = Owned To Guaranteed, Arg[2] = Owned To Guaranteed and Exploded, Arg[3] = Dead> of Some_App.AppDelegate.application (Some_App.AppDelegate)(ObjectiveC.UIApplication, openURL : ObjectiveC.NSURL, options : [Swift.String : Swift.AnyObject]) -> Swift.Bool (AppDelegate.swift:100) 
1 Some_app      0x000000010005e7a8 @objc Some_App.AppDelegate.application (Some_app.AppDelegate)(ObjectiveC.UIApplication, openURL : ObjectiveC.NSURL, options : [Swift.String : Swift.AnyObject]) -> Swift.Bool (AppDelegate.swift:0) 
2 UIKit       0x000000018c1ee664 0x18bf34000 + 2860644 
3 UIKit       0x000000018c1ee168 0x18bf34000 + 2859368 
4 UIKit       0x000000018c1f5c30 0x18bf34000 + 2890800 
5 UIKit       0x000000018c1fb644 0x18bf34000 + 2913860 
6 UIKit       0x000000018c1fa9dc 0x18bf34000 + 2910684 
7 UIKit       0x000000018c1e6fd4 0x18bf34000 + 2830292 
8 UIKit       0x000000018c1e6eb4 0x18bf34000 + 2830004 
9 FrontBoardServices    0x00000001905ffbe0 0x1905d8000 + 162784 
10 FrontBoardServices    0x00000001905fff60 0x1905d8000 + 163680 
11 CoreFoundation     0x00000001868eb8b4 0x18680c000 + 915636 
12 CoreFoundation     0x00000001868eb348 0x18680c000 + 914248 
13 CoreFoundation     0x00000001868e901c 0x18680c000 + 905244 
14 CoreFoundation     0x00000001868157fc 0x18680c000 + 38908 
15 GraphicsServices    0x00000001918a316c 0x191898000 + 45420 
16 UIKit       0x000000018bfae5e4 0x18bf34000 + 501220 
17 Some app      0x000000010005eaa4 main (AppDelegate.swift:14) 
18 libdyld.dylib     0x000000019bb128b4 0x19bb10000 + 10420 

Wydaje się, że gdy Facebook oddzwania mój app crash występuje w sposobie mojego AppDelegateopenURL. Jak wspomniano powyżej, istnieją dwa sposoby zakodowania tej metody od iOS9 i próbowałem obu. Jeśli usuniemy kod Facebooka w metodzie, to nie ulegam awarii, ale nie loguję się. Tak więc linia, która się zawiesza, to linia Facebooka. A to tylko zawiesza się, jeśli moja aplikacja została zainstalowana z archiwum. Jakieś pomysły? Może SDK Facebooka ma błąd w tym konkretnym przypadku?

Odpowiedz

11

znalazłem moją odpowiedź

Wygląda na to, że był to Tryb Release tylko kwestią. Po włączeniu Xcode do uruchamiania wersji Release byłem w stanie debugować mój problem. Wynika to z parametru sourceApplication, który w trybie zwolnienia musi być unwrapped. Nie mam pojęcia dlaczego, ale przynajmniej udało mi się.

func application(app: UIApplication, openURL url: NSURL, options: [String : AnyObject]) -> Bool 
{ 
     return FBSDKApplicationDelegate.sharedInstance().application(
      app, 
      openURL: url, 
      sourceApplication: options["UIApplicationOpenURLOptionsSourceApplicationKey"] as! String, 
      annotation: nil) 
} 
+0

Dzięki. to uratuje mój jeden dzień. –

+0

@Valentin Mercier, używam obiektywu C i mam również podobny problem. Jeśli uruchomię kompilację z mojego komputera, nie nastąpi awaria, ale gdy uruchomię tę samą kompilację z kompilacji moich kolegów, nastąpi awaria. Więc możesz sugerować na ten temat. – Ranjit

Powiązane problemy