gpt4 book ai didi

mysql - 如何使用 AES_ENCRYPT 在 MySQL 中安全地存储数据

转载 作者:可可西里 更新时间:2023-11-01 06:52:44 24 4
gpt4 key购买 nike

我们在 MySQL 中存储敏感数据,我想使用 AES_ENCRYPT(data, 'my-secret-key-here') 然后使用 AES_DECRYPT,效果很好。我最大的问题是如何保护 key ?以前我只是将 key 存储在一个 web PHP 文件中,所以像这样:

define("ENCRYPTION_KEY", 'my-secret-key-here');

但这确实行不通,因为我们的 MySQL 服务器和 Web 服务器是同一台物理机器,所以如果有人获得了对服务器的访问权限,他们可以获得存储在 MySQL 中的加密数据和 key 。

有什么想法吗?我在想我需要将 key 移动到单独的服务器,然后远程读取它。或者,如何为每条数据动态生成加密 key 。例如获取 customer_id 并在其上运行 md5,然后将其用作 key 。

最佳答案

将 key 放在一个文件中,将文件所有者更改为与网络服务器相同的用户。删除该组和其他所有人对该文件的所有权限。

super 用户 (https://superuser.com/questions/139393/linux-file-permissions-access-control-query) 上有一个类似的问题——我相信您可以在那里获得更好的帮助,或者只是通过谷歌搜索有关您正在运行的系统上的文件权限的更多信息。

关于mysql - 如何使用 AES_ENCRYPT 在 MySQL 中安全地存储数据,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/4697068/

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