Swift URL字符串编码崩溃在iOS上?

时间:2014-09-24 21:10:40

标签: ios swift url-encoding

我有一个URL字符串,其末尾附加了变量,如下所示:

.../create?title=My Apartment

我想逃避任何无效的字符(如空格),但是当我尝试这样做时,我使用以下内容在模拟器和设备(iOS 8.0)中崩溃:

NSLog("Item1: \(item)")
NSLog("Item2: \(item.title)")

if let scrubbed = item.title.stringByAddingPercentEncodingWithAllowedCharacters(NSCharacterSet.URLHostAllowedCharacterSet()) {
    NSLog("Scrubbed: \(scrubbed)")
} else {
    NSLog("Nope!")
}

我在模拟器上看到的 ,是:

2014-09-24 16:59:19.120 MyApp[16406:171349] Item1: MyApp.PostItem
2014-09-24 16:59:19.121 MyApp[16406:171349] Item2: My Apartment
2014-09-24 16:59:19.125 MyApp[16406:171349] Scrubbed: My              0X0P+0partment

请注意该擦洗字符串的奇怪之处。它在一段时间后崩溃,抱怨一个构造不良的NSURL对象,不出所料。

当我在设备上运行时,我在试图打印EXC_BAD_ACCESS的{​​{1}}声明中NSLog()崩溃了

Scrubbed:

我怎样才能弄清楚这里发生了什么?我本来希望在控制台中打印出2014-09-24 17:04:37.378 MyApp[4346:2048259] Item1: MyApp.PostItem 2014-09-24 17:04:37.379 MyApp[4346:2048259] Item2: My Apartment (lldb) po scrubbed error: <EXPR>:1:1: error: non-nominal type '$__lldb_context' cannot be extended extension $__lldb_context { ^ <EXPR>:11:5: error: 'PostManager.Type' does not have a member named '$__lldb_wrapped_expr_3' $__lldb_injected_self.$__lldb_wrapped_expr_3( ^ ~~~~~~~~~~~~~~~~~~~~~~ (lldb) 之前就像这样崩溃了。模型对象中的Nope!值由String提供。

修改:我能够从预先清理的值中获得一些UITextField输出:

NSData

编辑2:我可以在Xcode中确认此崩溃,并在操场上传递。似乎是一个错误 - 但在哪里? Xcode的?编译器?运行

编辑3:如果我尝试使用NSLog("Data: \(item.title.dataUsingEncoding(NSUTF8StringEncoding, allowLossyConversion: false))") ... 2014-09-24 17:18:43.620 MyApp[4367:2051348] Data: Optional(<4d792041 70617274 6d656e74>) 打印出变量值,则只会出现此错误。如果我完全避免这样做,只是使用变量,每个人都很高兴。

1 个答案:

答案 0 :(得分:5)

看起来像NSCharacterSet.URLHostAllowedCharacterSet()转义会生成奇怪的unicode字符串,在使用此字符串作为第一个参数的情况下会强制NSLog崩溃。

有几种方法可以避免这种情况,你肯定应该使用它们:

  • 就你在URL查询中使用它而言,你肯定应该使用不同的字符集 - NSCharacterSet.URLQueryAllowedCharacterSet()

  • 使用print/println

  • scrubbed传递给NSLog作为参数NSLog("Scrubbed: %@", scrubbed)

任何这些“解决方法”都可以解决问题。