返回顶部
首页 > 资讯 > 精选 >如何在MongoDB客户端字段级加密中保持一致的加密密钥?
  • 955
分享到

如何在MongoDB客户端字段级加密中保持一致的加密密钥?

2024-02-06 09:02:39 955人浏览 独家记忆
摘要

问题内容 我正在使用 mongoDB 客户端字段级加密来加密和解密数据。但是,我注意到每次执行程序时,原始二进制密钥都会发生变化。这使得我很难检索以前加密的数据,因为我无法使用新密钥对

问题内容

我正在使用 mongoDB 客户端字段级加密来加密和解密数据。但是,我注意到每次执行程序时,原始二进制密钥都会发生变化。这使得我很难检索以前加密的数据,因为我无法使用新密钥对其进行解密。

有没有办法在 MonGoDB 中维护客户端字段级加密的一致加密密钥?如果可以,我该怎么做?

https://www.mongodb.com/docs/manual/core/csfle/fundamentals/manual-encryption/#std-label-csfle-fundamentals-manual-encryption

Https://go.dev/play/p/6W8e0OiPV2L

我正在尝试在 MongoDB 社区项目中实现客户端字段级加密,以便在将文档中的某些字段存储到数据库之前对其进行加密,然后在从数据库检索它们时对其进行解密。

我一直在关注 MongoDB 文档,并且能够在第一次执行程序时成功加密和解密数据。但是,我注意到每次再次运行程序时密钥都会发生变化,并且我想保持密钥不变。


正确答案


这些行应该被删除:

// drop the key vault collection in case you created this collection
// in a previous run of this application.
if err = client.database(keyvaultdb).collection(keyvaultcoll).drop(context.todo()); err != nil {
    log.fatalf("collection.drop error: %v", err)
}

仅当密钥尚不存在时才需要以下行:

dataKeyID, err := clientEnc.CreateDataKey(context.TODO(), provider, dataKeyOpts)
if err != nil {
    log.Fatalf("CreateDataKey error: %v", err)
}

也许首先调用 clientenc.geTKEybyaltname 来检查密钥是否存在。

通过说“原始二进制密钥发生变化”,我认为您的意思是数据加密密钥 (dek) 发生变化。这是由于存储 dek 的集合被删除所致。

请参阅密钥和密钥保管库:

客户主密钥 (cmk) 是您用来加密数据加密密钥 (dek) 的密钥....

数据加密密钥 (dek) 是用于加密 mongodb 文档中的字段的密钥。您将数据加密密钥存储在使用 cmk 加密的 key vault 集合中......

如果您删除数据加密密钥 (dek),则使用该 dek 加密的所有字段将永久无法读取。

如果您删除 cmk,则使用该 cmk 加密的 dek 加密的所有字段将永久无法读取。

以上就是如何在MongoDB客户端字段级加密中保持一致的加密密钥?的详细内容,更多请关注编程网其它相关文章!

--结束END--

本文标题: 如何在MongoDB客户端字段级加密中保持一致的加密密钥?

本文链接: https://lsjlt.com/news/561342.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作