gpt4 book ai didi

sqlite - 加密 SQLITE 数据库并在 Windows VCL 应用程序中与 FireDac 一起使用

转载 作者:行者123 更新时间:2023-12-03 07:26:18 24 4
gpt4 key购买 nike

我正在使用 c++ builder 编写 Windows VCL 桌面。该应用程序使用 Firedac 和 SQLite 数据库。

我想保护这个 SQLite 数据库:

  • 只有我的 vcl 应用程序可以连接并使用它
  • 其他程序和人不能使用 SQLite 文件

  • 到目前为止,我发现我能做的最简单的事情是 加密 ,您可以让任何没有正确密码的人在尝试打开它时收到类似“ 此文件不是数据库 ”的消息。

    是的,我们可以使用 Embarcadero VCL 做到这一点, doc.使用 TFDSQLiteSecurity 组件和这些行:
    FDSQLiteSecurity1->Password = "";/* we are protecting (encrypting) our uncyphered database*/
    FDSQLiteSecurity1->ToPassword = 'newpassword';
    FDSQLiteSecurity1->ChangePassword();

    不幸的是,VCL Firedac 应用程序无法连接到加密的 sqlite 数据库,因此它必须先对其进行解密。

    为了使事情正常进行,我的程序启动并解密数据库(删除密码),然后它连接到数据库并使用它。完成后,我再次重新加密数据库(关闭应用程序时)。

    问题:
    在此期间(我的程序已启动并运行且数据库未加密)我可以阻止其他程序打开 SQLITE 数据库吗?有没有更好的方法,我愿意接受任何建议

    最佳答案

    一旦它被 FireDac 加密,只需在 FDConnection 上设置适当的属性。那些将是 password到密码和encrypt到加密方法。

    Firedac 可以打开它自己加密的 SQLite 数据库,因此问题可以通过这样做作为更好的方法自行解决。其他程序只能看到磁盘上的加密版本,没有密码就无法打开。

    关于sqlite - 加密 SQLITE 数据库并在 Windows VCL 应用程序中与 FireDac 一起使用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58981567/

    24 4 0
    Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
    广告合作:1813099741@qq.com 6ren.com