我有一个iOS应用,可通过WatchConnectivity与配对的手表进行通讯。在大多数情况下,它可以在模拟器和设备上正常工作。
问题:
在模拟器上进行开发期间,当我尝试使用WCSession.default.sendMessage(_:replyHandler:errorHandler:)
将iOS的直接消息发送到watchOS时,会出现以下通信错误:
Error Domain=WCErrorDomain Code=7007
"WatchConnectivity session on paired device is not reachable."
我已经阅读了this篇相关文章,但不适用于我的情况,因为我的应用程序可以正常运行。
我的问题:
当应用程序在iOS模拟器上运行时,手表模拟器怎么可能无法访问?
一段时间后重试sendMessage
是否有意义?
有什么解决方法吗?
答案 0 :(得分:0)
作为一种解决方法,我修改了sendMessage
函数,以便在发生此错误的情况下重试多次传输。从那时起,所有sendMessage
传输都成功执行。
func sendMessage(_ message: [String: AnyObject],
replyHandler: (([String: Any]) -> Void)?,
errorHandler: ((Error) -> Void)?) {
guard let communicationReadySession = communicationReadySession else {
// watchOS: A session is always valid, so it will never come here.
print("Cannot send direct message: No reachable session")
let error = NSError.init(domain: kErrorDomainWatch,
code: kErrorCodeNoValidAndReachableSession,
userInfo: nil)
errorHandler?(error)
return
}
/* The following trySendingMessageToWatch sometimews fails with
Error Domain=WCErrorDomain Code=7007 "WatchConnectivity session on paired device is not reachable."
In this case, the transfer is retried a number of times.
*/
let maxNrRetries = 5
var availableRetries = maxNrRetries
func trySendingMessageToWatch(_ message: [String: AnyObject]) {
communicationReadySession.sendMessage(message,
replyHandler: replyHandler,
errorHandler: { error in
print("sending message to watch failed: error: \(error)")
let nsError = error as NSError
if nsError.domain == "WCErrorDomain" && nsError.code == 7007 && availableRetries > 0 {
availableRetries = availableRetries - 1
let randomDelay = Double.random(min: 0.3, max: 1.0)
DispatchQueue.main.asyncAfter(deadline: .now() + randomDelay, execute: {
trySendingMessageToWatch(message)
})
} else {
errorHandler?(error)
}
})
} // trySendingMessageToWatch
trySendingMessageToWatch(message)
} // sendMessage