我有一个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>)
打印出变量值,则只会出现此错误。如果我完全避免这样做,只是使用变量,每个人都很高兴。
答案 0 :(得分:5)
看起来像NSCharacterSet.URLHostAllowedCharacterSet()
转义会生成奇怪的unicode字符串,在使用此字符串作为第一个参数的情况下会强制NSLog崩溃。
有几种方法可以避免这种情况,你肯定应该使用它们:
就你在URL查询中使用它而言,你肯定应该使用不同的字符集 - NSCharacterSet.URLQueryAllowedCharacterSet()
。
使用print/println
将scrubbed
传递给NSLog
作为参数NSLog("Scrubbed: %@", scrubbed)
任何这些“解决方法”都可以解决问题。