繁体   English   中英

加密 SQLITE 数据库并在 windows VCL 应用程序中将其与 FireDac 一起使用

[英]Encrypt SQLITE database and use it with FireDac in a windows VCL application

我正在使用 c++ 构建器编写 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 数据库,它已经加密了自己,因此问题通过这样做作为更好的方法自行解决。 其他程序只能看到磁盘上的加密版本,没有密码就无法打开。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM