Ios 未调用handleWatchKitExtensionRequest时出现问题?

Ios 未调用handleWatchKitExtensionRequest时出现问题?,ios,json,swift,parse-platform,apple-watch,Ios,Json,Swift,Parse Platform,Apple Watch,我正在尝试更新我的watch kit应用程序,以添加一些从JSON文件解析的数据。我正在结合从Parse获取一些数据来完成这项工作 我得到一个错误: iPhone应用程序中的UIApplicationLegate从未在-[UIApplicationLegate应用程序:handleWatchKitExtensionRequest:reply:]中调用过reply() 我曾尝试调试handleWatchKitExtensionRequest,但它没有崩溃,而且我添加的println由于某种原因从未

我正在尝试更新我的watch kit应用程序,以添加一些从JSON文件解析的数据。我正在结合从Parse获取一些数据来完成这项工作

我得到一个错误:

iPhone应用程序中的UIApplicationLegate从未在-[UIApplicationLegate应用程序:handleWatchKitExtensionRequest:reply:]中调用过reply()

我曾尝试调试
handleWatchKitExtensionRequest
,但它没有崩溃,而且我添加的
println
由于某种原因从未打印

这是我的代码:

func application(application: UIApplication, handleWatchKitExtensionRequest userInfo: [NSObject : AnyObject]?, reply: (([NSObject : AnyObject]!) -> Void)!) {
    var favouritesArrayDefaults: NSMutableArray! = [""]

    println("1")
    var keyStore = NSUbiquitousKeyValueStore()
    if keyStore.arrayForKey("FavouritesList") != nil {
        let tempFavourites: NSArray = keyStore.arrayForKey("FavouritesList")!
        favouritesArray = tempFavourites.mutableCopy() as! NSMutableArray
    } else {
        println("3")
    }

    println(favouritesArrayDefaults)

    if let pfqueryRequest: AnyObject = (userInfo as? [String: AnyObject])?["parkName"] {
        println("HELLO")

        let taskID = beginBackgroundUpdateTask()
        //Must start and end task to allow time for query to complete

        var name = ""
        var waitTime = ""
        var hasWaitTime = false
        var fastPass = false
        var heightRestriction = false
        var singleRider = false
        var disabledAccess = false
        var mustSee = false
        var fastPassTime = ""

        var namesArray: [String] = []
        var waitTimesArray: [String] = []
        var favouritesArray: [String] = []
        var hasWaitTimeArray: [Bool] = []
        var fastPassArray: [Bool] = []
        var heightRestrictionArray: [Bool] = []
        var singleRiderArray: [Bool] = []
        var disabledAccessArray: [Bool] = []
        var mustSeeArray: [Bool] = []
        var fastPassTimeArray: [String] = []

        var query = PFQuery(className: pfqueryRequest as! String)
        query.orderByAscending("Name")
        var objects = query.findObjects()

        if let objects = objects as? [PFObject] {
            for object in objects {
                name = (object.objectForKey("Name") as? String)!
                waitTime = (object.objectForKey("WaitTime") as? String)!
                hasWaitTime = (object.objectForKey("HasWaitTime") as? Bool)!
                fastPass = (object.objectForKey("FastPass") as? Bool)!
                heightRestriction = (object.objectForKey("HeightRestriction") as? Bool)!
                singleRider = (object.objectForKey("SingleRider") as? Bool)!
                disabledAccess = (object.objectForKey("DisabledAccess") as? Bool)!
                mustSee = (object.objectForKey("MustSee") as? Bool)!

                namesArray.append(name)
                waitTimesArray.append(waitTime)
                hasWaitTimeArray.append(hasWaitTime)
                fastPassArray.append(fastPass)
                heightRestrictionArray.append(heightRestriction)
                singleRiderArray.append(singleRider)
                disabledAccessArray.append(disabledAccess)
                mustSeeArray.append(mustSee)
            }

            var urlString = (DataManager.sharedInstance.getParkByName(pfqueryRequest as! String)?.dataSource)!

            if let url = NSURL(string: urlString) {
                if let data = NSData(contentsOfURL: url, options: .allZeros, error: nil) {
                    let json = JSON(data: data)

                    for count in 0...json.count - 1 {
                        let rideName: JSON = json[count]["name"]
                        let waitTime: JSON = json[count]["waitTime"]
                        var fastPassTime: JSON = json[count]["fastPass"]

                        if find(namesArray, rideName.string!) != nil {
                            let index = find(namesArray, rideName.string!)

                            var modifiedWaitTime = "".join(waitTime.string!.componentsSeparatedByCharactersInSet(NSCharacterSet.decimalDigitCharacterSet().invertedSet))

                            if waitTime == "Down" || waitTime == "Closed" {
                                modifiedWaitTime = "Closed"
                            }

                            if fastPassTime.string == nil {
                                fastPassTime = "Unavailable"
                            } else if fastPassTime.string == "N/A" {
                                fastPassTime = "Expired"
                            }

                            waitTimesArray.removeAtIndex(index!)
                            waitTimesArray.insert(waitTime.string!, atIndex: index!)

                            fastPassTimeArray.removeAtIndex(index!)
                            fastPassTimeArray.insert(fastPassTime.string!, atIndex: index!)
                        }
                    }
                }
            }

            for favourite in favouritesArrayDefaults {
                favouritesArray.append(favourite as! String)
            }

            println(fastPassTimeArray)
            reply(["success": true, "name": namesArray, "waitTime": waitTimesArray, "hasWaitTime": hasWaitTimeArray, "favourites": favouritesArray, "fastPass": fastPassArray, "heightRestriction": heightRestrictionArray, "singleRider": singleRiderArray, "disabledAccess": disabledAccessArray, "mustSee": mustSeeArray, "fastPassTime": fastPassTimeArray])

            endBackgroundUpdateTask(taskID)
        }
    } else if let pfqueryRequest: AnyObject = (userInfo as? [String: AnyObject])?["parkNameSubmit"] {
        let taskID = beginBackgroundUpdateTask()

        var query = PFQuery(className: pfqueryRequest as! String)
        //query.orderByAscending("Name")
        query.whereKey("Name", equalTo: userInfo!["name"]!)
        query.getFirstObjectInBackgroundWithBlock {
            (object: PFObject?, error: NSError?) -> Void in
            if error != nil {
                println("The getFirstObject request failed.")
            } else {
                if let obj = object {
                    obj.setValue(userInfo!["waitTime"], forKey: "WaitTime")
                    obj.saveInBackground()
                }
                println("Successfully retrieved the object.")
            }
        }

        reply(["success": true, "message": "Hello!"])

        endBackgroundUpdateTask(taskID)
    }
}
很抱歉代码太多,但我真的不知道问题出在哪里


有人有什么想法吗?

把你的
reply()。问题是在任何情况下都应该调用
reply()
处理程序,但在您的示例中,如果
pfqueryRequest
nil
则永远不会调用该处理程序。

序列化
reply()
处理程序中的自定义对象

发生此错误的另一个原因是。如果您尝试这样做,iOS/watchOS将无法将您的对象序列化到应答的
plist
文件,这就是通信的方式。由于文件序列化失败,因此从未写出该文件,WatchKit扩展认为从未调用过
reply()
,因此出现错误

您必须将这些对象分解为更基本的对象类型,或者使用
NSKeyedArchiver
将这些自定义对象编码为
NSData
,然后在回复中发送并解码,然后使用
nskeyedunachiver
将该数据解码回通信扩展端的自定义对象

立即启动后台任务以防止iOS暂停您的应用程序

此外,iOS还可以暂停应用程序的执行(即使您所做的只是验证请求或先创建变量)

发件人:

由于此方法可能在应用程序处于后台时调用,因此在实现开始时调用beginBackgroundTaskWithName:expirationHandler:方法并在处理回复并执行回复块后调用endBackgroundTask:方法。启动后台任务可确保应用程序在有机会发送回复之前不会被挂起

iOS应用程序的Xcode控制台输出在连接到WatchKit扩展进程时不可用

在WatchKit扩展上调试时,将不会显示从iOS应用程序写入控制台的
print()
println()
NSLog()
或类似方法

解决这个问题的一种方法是在模拟器中运行WatchKit应用程序,然后在iOS模拟器中打开iOS应用程序。完成后,返回Xcode并转到
Debug>attachtoprocess
,在列表中找到iOS应用程序的进程。Xcode现在应该显示来自两个进程的控制台输出(但是您需要使用Xcode调试/控制台区域顶部的控件在它们之间切换)

在Watch Connectivity Framework中使用更新的WatchKit API

我强烈推荐使用较新的而不是较旧的
+[WKInterfaceController openParentApplication:reply://code>。苹果已经做了大量工作来改进watchOS应用程序与其主机iOS应用程序之间共享数据的初始机制


我个人在使用原始API时遇到了很多问题,当我放弃对watchOS 1.x的支持并转到watchOS 2.x及更高版本时,所有问题都消失了。

我在不相关的代码中有另一个回复。我将更新我的代码以进行演示。我猜你犯了一个错误?你应该对
else
块有一个关闭条件,不是吗t
else if
one。我现在添加了一个
else
,但这没有什么区别。我应该补充一点,我有相同的代码(减去JSON的东西),它以前工作得很好。好吧,如果你调用
reply()
在处理程序的最后一行-它应该可以工作。我在处理这个处理程序时从来没有遇到过任何问题。是的,它在最后一行被调用。这个问题解决了吗?