我正在制作一个应用程序,其中必须将远程数据库中的数据存储到本地 sqlite3 数据库中。
Problem is - when any string to be inserted contains unicode character such as: \U00a0 or \U2022 or \U2019, it crashes.
崩溃的代码部分是这样的-
NSString *insertQuery = @"insert into XYZ(field1,field2) values (@"1",[recordDict objectForKey:@"field2"]);
// recordDict contains value: @"\U00a0 \U00a0 \U00a0 \U00a0The Cadfsdfsdfptain\U2019s" for key: @"field2"
sqlite3_stmt *insertStmnt;
const char *sql = [insertQuery cStringUsingEncoding:1];
printf("insertQuery - %s",sql); // it is showing insertQuery - (null) and crashing at next line
if(sqlite3_prepare_v2(database, sql, -1, &insertStmnt, NULL) != SQLITE_OK){
NSLog(@"Error while creating insert statement. '%s'",sqlite3_errmsg(database));
}
谁能建议我如何解决这个问题?
谢谢
米拉杰
最佳答案
cStringUsingEncoding:
当字符串无法无损转换为指定编码时返回 NULL
,从而导致崩溃。您可以使用 canBeConvertedToEncoding:
确保可以进行转换。
此外,值 1
对应于 NSASCIIStringEncoding
,对于具有 Unicode 字符的字符串肯定会失败。 NSUTF8StringEncoding
可能更合适。
关于string - 由于字符串中的 unicode 字符导致应用程序崩溃,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/4325311/