快速 – WatchKit短信与预设的身体

我发现 this question应该帮助了我,但是解决方案对我来说并不工作,我不知道有没有改变,或者问题是我的代码
let messageBody = "hello"
let urlSafeBody = messageBody.stringByAddingPercentEncodingWithAllowedCharacters(NSCharacterSet.URLHostAllowedCharacterSet())
print("URLSAFEBODY: \(urlSafeBody)")
WKExtension.sharedExtension().openSystemURL(NSURL(string: "sms:&body=\(urlSafeBody)")!)

当执行这个代码时,我收到消息,可选的urlSafeBody在nil被强行解开,导致崩溃。为什么urlSafeBody没有?我知道我强制解开它,但我不明白为什么在明确分配之后是没有的。

这不是urlSafeBody是零。从print语句中可以看到,它包含一个可选的字符串:

URLSAFEBODY: Optional(“hello”)

这实际上会在下一个语句中成为链的问题,因为在插入该字符串之前您尚未展开该字符串。

如果你检查了你的NSURL字符串URL,你会看到它包含:

sms:&body=Optional(“hello”)

这将导致NSURL初始化失败,因为它的字符串URL格式错误。然后发生致命错误,因为您强制打开NSURL(string :)的零结果

如何解决这个问题

您要有条件地解开任何可能为零的字符串。你可以通过如果允许或保护让可选绑定来做到这一点:

let messageBody = "hello"
let urlSafeBody = messageBody.stringByAddingPercentEncodingWithAllowedCharacters(NSCharacterSet.URLHostAllowedCharacterSet())
if let urlSafeBody = urlSafeBody,url = NSURL(string: "sms:&body=\(urlSafeBody)") {
    WKExtension.sharedExtension().openSystemURL(url)
}

请注意,urlSafeBody在字符串插值中被使用之前被展开,并且url在初始化后也被解开。

由于确定url不为零,因此可以安全地传递给openSystemURL。

你应该始终努力避免强制解开变量,这可能是零,因为这肯定会导致崩溃。

相关文章

软件简介:蓝湖辅助工具,减少移动端开发中控件属性的复制和粘...
现实生活中,我们听到的声音都是时间连续的,我们称为这种信...
前言最近在B站上看到一个漂亮的仙女姐姐跳舞视频,循环看了亿...
【Android App】实战项目之仿抖音的短视频分享App(附源码和...
前言这一篇博客应该是我花时间最多的一次了,从2022年1月底至...
因为我既对接过session、cookie,也对接过JWT,今年因为工作...