gpt4 book ai didi

php - SQLite、SQLCipher、PHP 和 PowerShell 注意事项

转载 作者:行者123 更新时间:2023-12-03 01:25:53 28 4
gpt4 key购买 nike

所以我正在为我们的 Intranet 制作这个很棒的 webapp,我想使用 SQLite。为了增加安全性,我认为使用 Zetetic SQLCipher 会很棒,它使 DB 文件加密且不可读,以防有人窃取它。
我知道如何将它与 PHP PDO 一起使用,但问题是最新版本仅适用于 PHP 7.1 已有 2 年历史,我不确定是否会有更多开发
https://github.com/kynetiv/php_pdo_sqlcipher
我没有找到任何其他 PHP PDO 库,但也许我忽略了一些东西。
接下来是 PowerShell,它是我的应用程序自动化和收集数据所必需的。在这里,我在考虑是否应该通过将由 PHP 处理的临时 CSV 文件写入 SQLite,或者是否应该通过 PSSQLite 直接从 PowerShell 访问 SQLite ...但是似乎 PowerShell 中没有支持 SQLCipher 的模块,所以我会不得不放弃加密。
想法?

最佳答案

我们有一个很棒的sibling site致力于安全性,他们要求每个人在处理安全性时首先考虑的事情之一是攻击媒介是什么以及您试图减轻什么风险。如果你已经这样做了,我很抱歉,你可以忽略这个。
然而,我之所以这么说,是因为一体式解决方案往往会给人一种错误的安全感。例如,如果您认为您的数据库很可能和/或可能受到物理损害,那么他们也不会获取包含密码的文件,这又是什么意思呢?有ways to mitigate这个问题也是如此,但它们也会导致其他问题/复杂性。
我说这一切只是建立了一个使用数据库加密的应用程序,所以它是最重要的。对于我们的应用程序,我们使用 Doctrine 作为 ORM,我们使用了 this根据需要加密列。我们的应用程序是用 Symfony 构建的,这可能不是您的选择,但它极大地简化了事情,包括您的 PowerShell 问题(稍后会详细介绍)。
回到您的问题,该 repo 似乎是 Windows 的唯一二进制文件,除非您愿意自己构建它,否则我建议您避免使用它。 PHP 7.1 已经结束生命周期,PHP 8 将在今年第四季度发布。有alternatives但它们都需要许可证或自行构建东西。所以除非你愿意因此,我认为 SqlCipher 不适合你
对于您的自动化,我再一次强调与 Symfony Console 合作是多么美妙。应用程序。只需几行代码,您就可以拥有一个 CLI,如果您想将其编译为 PHAR,则只需一个可执行文件。我们有很多内部工具可以这样做。
如果您不想走 Symfony(或其他框架)路线,您仍然可以使用一堆参数调用您的 PHP 脚本。先写入CSV文件还是直接调用更好?两者都是绝对有效的选项,因此它实际上取决于您的用例和数据集。对我来说,如果我的 PHP 代码可以读取文件而不是进行 API 调用或从标准输入或类似的读取,那么调试起来会容易得多。因此,如果您的 PowerShell 代码可以执行任何逻辑,然后使用“处理此文件”调用 PHP,那么从我的角度来看,这通常是最好的。但是,如果您更擅长 PowerShell,那么处理可能会更好。老实说,这真的取决于。
编辑
我只是想在应用程序级别添加更多关于加密的信息。加密数据令人讨厌的一件事是它通常不可搜索,至少使用数据库本身是不可搜索的。但是,有办法解决这个问题:

  • Building Searchable Encrypted Databases with PHP and SQL
  • CipherSweet: Searchable Encryption Doesn't Have to be Bitter

  • 此外,如果不需要从数据库中进行搜索,而您只是想要一个地方来存储让您的​​应用程序处理解密的东西,那么 PHP 通过 Sodium 库提供了一些非常棒且易于使用的加密。不幸的是,官方文档缺乏,但以下内容很好地揭开了事物的神秘面纱:
  • https://paragonie.com/blog/2017/06/libsodium-quick-reference-quick-comparison-similar-functions-and-which-one-use
  • https://github.com/paragonie/halite
  • 关于php - SQLite、SQLCipher、PHP 和 PowerShell 注意事项,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/63116767/

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