• 设为首页
  • 点击收藏
  • 手机版
    手机扫一扫访问
    迪恩网络手机版
  • 关注官方公众号
    微信扫一扫关注
    公众号

ios - SQLITE UTF-16 编码问题

[复制链接]
菜鸟教程小白 发表于 2022-12-13 03:43:06 | 显示全部楼层 |阅读模式 打印 上一主题 下一主题

好的,这几天我一直在努力解决这个问题。这里使用了几种技术,首先我使用 Unreal Engine 4 开发 iOS 游戏,并链接到 sqlite3 的静态库,我在 Windows 上为其创建数据库。

在 Windows 上一切正常,我创建了数据库,如果你进行 Pragma 编码;它显示 UTF-16LE。

但是,在 IOS 上,一切都崩溃了。首先,如果我什至尝试在 iOS 中使用 sqlite3_open16 函数创建一个空数据库,它会创建一个名称末尾有一堆垃圾的数据库,如果我打开它,并进行编译指示编码,它会说 UTF -8(没有表的空数据库)。 如果我尝试连接到现有的,有时我会“随机”成功,我认为这与出现在字符串末尾的奇怪字符再次有关,我怀疑这是编码问题。

用来打开数据库的函数是这样的:

bool Open(const TCHAR* ConnectionString)
{
    int32 Result = sqlite3_open16(ConnectionString, &DbHandle);
    return Result == SQLITE_OK;
}

在windows中运行良好,但在ios中存在上述问题。

根据他们的文档,他们使用 USC-2。从我在 sqlite 源代码中可以看出,它将使用 UTF-16LE。我需要做些什么来在这两者之间进行转换吗?或者还有什么我可能在这里遗漏的东西?有没有人有任何想法?希望不熟悉 UE4 的 friend 也能猜到一点。

编辑:我尝试过的事情的列表:

  1. 使用 UTF-8 函数 SQLITE 这些似乎工作正常。 UE4 有一个函数 TCHAR_TO_UTF8 并且有效。

  2. 尝试使用 Objective C 来确保 UTF-16LE 的编码,这给了我上面描述的“随机”成功。除了有时似乎只随机使用字符串末尾的奇怪随机文本 - 每当我现在尝试从数据库中提取数据时,它都会以随机问号'????'的形式返回。偶尔有汉字。我用来做这个的函数是:

    const TCHAR* UChimeraSqlDatabase::UTF16_To_PlatformEncoding(FString UTF16EncodedString)
    {
    #if PLATFORM_IOS
        const TCHAR* EncodedString = (const TCHAR *)([[[NSString stringWithFString : UTF16EncodedString] dataUsingEncoding:NSUTF16LittleEndianStringEncoding] bytes]);
    #else
        const TCHAR* EncodedString = *UTF16EncodedString;
    #endif
        return EncodedString;
    }
    
  3. 尝试使用Unreals .AppendChar 将L'\0'添加到String的末尾,不包括数字2的方法,没有成功。



Best Answer-推荐答案


如果您在调用 sqlite3_16 时在文件名末尾看到奇怪的字符,这听起来像是您的 UTF16 文件名没有 NULL 终止。

要指定数据库的编码,你实际上可以使用任何sqlite3_open函数创建它,但关键是一旦创建了数据库,你必须立即设置编码:

PRAGMA encoding = "UTF-16le";

一旦设置了编码,就无法更改它,因此请确保在创建数据库后首先执行此操作。

关于ios - SQLITE UTF-16 编码问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/27209559/

回复

使用道具 举报

懒得打字嘛,点击右侧快捷回复 【右侧内容,后台自定义】
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

关注0

粉丝2

帖子830918

发布主题
阅读排行 更多
广告位

扫描微信二维码

查看手机版网站

随时了解更新最新资讯

139-2527-9053

在线客服(服务时间 9:00~18:00)

在线QQ客服
地址:深圳市南山区西丽大学城创智工业园
电邮:jeky_zhao#qq.com
移动电话:139-2527-9053

Powered by 互联科技 X3.4© 2001-2213 极客世界.|Sitemap