ClientEncryption.decrypt()
On this page本页内容
New in version 4.2.
ClientEncryption.decrypt(encryptedValue)
-
ClientEncryption.decrypt()
decrypts theencryptionValue
if the current database connection was configured with access to the Key Management Service (KMS) and key vault used to encryptencryptionValue
.Returns: The decrypted value.
Syntax
ClientEncryption.decrypt
has the following syntax:
clientEncryption = db.getMongo().getClientEncryption()
clientEncryption.decrypt(encryptedValue)
The encryptedValue
must be a binary data
object with subtype 6 created using client-side field level encryption.
Behavior
Read operations issued from a database connection configured
with access to the correct Key Management Service (KMS) and Key Vault can automatically decrypt field values encrypted using ClientEncryption.encrypt()
. Clients only need to use decrypt()
to decrypt Binary
subtype 6 values not stored within a document field.
Enable Client-Side Field Level Encryption on Database Connection
The mongosh
client-side field level encryption methods require a database connection with client-side field level encryption enabled. If the current database connection was not initiated with client-side field level encryption enabled, either:
- Use the
Mongo()
constructor from themongosh
to establish a connection with the required client-side field level encryption options. TheMongo()
method supports the following Key Management Service (KMS) providers for Customer Master Key (CMK) management:or
- Use the
mongosh
command line options to establish a connection with the required options. The command line options only support the Amazon Web Services KMS provider for CMK management.
Example
The following example uses a locally managed KMS for the client-side field level encryption configuration.
Create Your Encrypted Connection
Create Your Encrypted Client
Use the Mongo()
constructor with the client-side field level encryption options configured to create a database connection. Replace the mongodb://myMongo.example.net
URI with the connection string URI of the target cluster.
encryptedClient = Mongo(
"mongodb://myMongo.example.net:27017/?replSetName=myMongo",
autoEncryptionOpts
)
Decrypt Your Data
Retrieve the ClientEncryption
object and use the ClientEncryption.decrypt()
method to decrypt a value encrypted by ClientEncryption.encrypt()
.
clientEncryption = encryptedClient.getClientEncryption();
clientEncryption.decrypt(BinData(6,"AmTi2H3xaEk8u9+jlFNaLLkC3Q/+kmwDbbWrq+h9nuv9W+u7A5a0UnpULBNZH+Q21fAztPpU09wpKPrju9dKfpN1Afpj1/ZhFcH6LYZOWSBBOAuUNjPLxMNSYOOuITuuYWo="))
Example Results
If successful, decrypt()
returns the decrypted value:
"123-45-6789"
Learn More
For complete documentation on initiating MongoDB connections with client-side field level encryption enabled, see Mongo()
.