从AppStore或TestFlight启动时应用程序崩溃,但其他工作正常

时间:2016-09-30 10:07:49

标签: ios swift crash testflight crash-reports

我的申请更新已被拒绝。在拒绝消息中,他们写了“发布时应用程序崩溃”。然后我尝试了我的应用程序,但无法使其崩溃。所以我使用了TestFlight并注意到当我从TestFlight或AppStore启动我的应用程序时,它在启动时崩溃了。但是如果我正常启动我的应用程序,它确实可以正常运行而不会崩溃。问题是自iOS 10更新以来发生了这个错误。现在,我在AppStore上发布时,我的应用程序也会崩溃,而它在2周后工作正常。

Apple给我发了一个崩溃日志:

Incident Identifier: 001969F1-F275-4AC3-AFE1-E0426957B702
CrashReporter Key:   5ad9695e945a7d5eb5d61fd18d1c3989ccd155b4
Hardware Model:      xxx
Process:             MyApp [400]
Path:                /private/var/containers/Bundle/Application/644423A4-EFE7-41B1-99D9-47B46338A6E2/MyApp.app/MyApp
Identifier:          com.MyApp.com
Version:             20160527 (2.7.9)
Code Type:           ARM-64 (Native)
Role:                Foreground
Parent Process:      launchd [1]
Coalition:           com.MyApp.com [451]


Date/Time:           2016-09-22 11:19:22.6893 -0700
Launch Time:         2016-09-22 11:19:22.4164 -0700
OS Version:          iPhone OS 10.0.1 (14A403)
Report Version:      104

Exception Type:  EXC_BREAKPOINT (SIGTRAP)
Exception Codes: 0x0000000000000001, 0x000000010008a864
Termination Signal: Trace/BPT trap: 5
Termination Reason: Namespace SIGNAL, Code 0x5
Terminating Process: exc handler [0]
Triggered by Thread:  0

Filtered syslog:
None found

Thread 0 name:  Dispatch queue: com.apple.main-thread
Thread 0 Crashed:
0  MyApp                         0x1000efd3c specialized AppDelegate.application(UIApplication, didFinishLaunchingWithOptions : [NSObject : AnyObject]?) -> Bool (AppDelegate.swift:218)
1  MyApp                         0x1000ed310 @objc AppDelegate.application(UIApplication, didFinishLaunchingWithOptions : [NSObject : AnyObject]?) -> Bool (AppDelegate.swift)
2  UIKit                          0x19888c42c <redacted> + 400
3  UIKit                          0x198a9cb70 <redacted> + 3524
4  UIKit                          0x198aa28e0 <redacted> + 1656
5  UIKit                          0x198ab7080 <redacted> + 48
6  UIKit                          0x198a9f8c4 <redacted> + 168
7  FrontBoardServices             0x1945798bc <redacted> + 36
8  FrontBoardServices             0x194579728 <redacted> + 176
9  FrontBoardServices             0x194579ad0 <redacted> + 56
10 CoreFoundation                 0x192986278 __CFRUNLOOP_IS_CALLING_OUT_TO_A_SOURCE0_PERFORM_FUNCTION__ + 24
11 CoreFoundation                 0x192985bc0 __CFRunLoopDoSources0 + 524
12 CoreFoundation                 0x1929837c0 __CFRunLoopRun + 804
13 CoreFoundation                 0x1928b2048 CFRunLoopRunSpecific + 444
14 UIKit                          0x1988855dc <redacted> + 608
15 UIKit                          0x198880360 UIApplicationMain + 208
16 MyApp                         0x1000ee818 main (AppDelegate.swift:58)
17 libdispatch.dylib              0x1918945b8 (Missing)

还有另外4个线程,但是这一个是崩溃的,所以我没有复制其余的。我做了一些研究,虽然我确实注意到我的崩溃日志没有完全翻译(因为我有所有的dsyms但是有什么奇怪的原因),我确实理解我在第217行崩溃了(告诉我,如果我'我错了)。我知道SIGTRAP大多数时候都会抛出NSExceptions。这条线本身就是:

let api = MyAppAPI.instance

该实例是一个单例。我的猜测是实例创建中的某些内容失败了。这是代码:

static var instance: MyAppAPI = {
    return Singleton.instance
}()

class MyAppAPI: Manager {
struct Singleton {
    static var configuration: NSURLSessionConfiguration = {
        var configuration = NSURLSessionConfiguration.defaultSessionConfiguration()
        let version = NSBundle.mainBundle().objectForInfoDictionaryKey("CFBundleShortVersionString") as? String ?? ""
        configuration.HTTPAdditionalHeaders = [
            "Accept": "application/vnd.MyApp.api+json, application/json;q=0.9",
            "User-Agent": "MyApp iOS/\(version)",
            "X-API-Version": "1.0.1"
        ]

        return configuration
        }()

    static var instance = MyAppAPI(configuration: configuration)
    static var baseURL : NSURL! = nil
}

我对这个错误非常绝望,我确实尝试了一些无法解决的问题。我在寻找合适的地方吗?有人有解决方案吗?任何形式的帮助将不胜感激。我愿意给任何可以找到我解决方案或帮我找到解决方案的人送礼!

1 个答案:

答案 0 :(得分:5)

我找到了解决问题的方法。

正如所料,它来自replicate

在函数内部func application(application: UIApplication, didFinishLaunchingWithOptions launchOptions: [NSObject: AnyObject]?) -> Bool

我将其更改为let userInfo = launchOpts[UIApplicationLaunchOptionsRemoteNotificationKey] as! NSDictionary,然后选中let userInfo = launchOpts[UIApplicationLaunchOptionsRemoteNotificationKey] as? NSDictionary以使所有代码运行if userInfo != nil到括号中。

如果它可以帮助任何人或者是否有人在努力解决此问题,请检查所有人userInfo并将其与!交换,如果需要(在?上),因为从TestFlight / AppStore启动似乎与安装的应用程序有不同的选项(只是一个猜测,不足以声称它)。