使用mysql数据库进行加密数据的literal搜索

eufgjt7s  于 2021-06-21  发布在  Mysql
关注(0)|答案(0)|浏览(268)

我使用以下函数对mysql数据库中的数据进行加密/解密:

'use strict';

const crypto = require('crypto');

const ENCRYPTION_KEY = process.env.ENCRYPTION_KEY; // Must be 256 bytes (32 characters)
const IV_LENGTH = 16; // For AES, this is always 16

function encrypt(text) {
  let iv = crypto.randomBytes(IV_LENGTH);
  let cipher = crypto.createCipheriv('aes-256-cbc', new Buffer(ENCRYPTION_KEY), iv);
  let encrypted = cipher.update(text);

  encrypted = Buffer.concat([encrypted, cipher.final()]);

  return iv.toString('hex') + ':' + encrypted.toString('hex');
}

function decrypt(text) {
  let textParts = text.split(':');
  let iv = new Buffer(textParts.shift(), 'hex');
  let encryptedText = new Buffer(textParts.join(':'), 'hex');
  let decipher = crypto.createDecipheriv('aes-256-cbc', new Buffer(ENCRYPTION_KEY), iv);
  let decrypted = decipher.update(encryptedText);

  decrypted = Buffer.concat([decrypted, decipher.final()]);

  return decrypted.toString();
}

module.exports = { decrypt, encrypt };

(来自此链接)
现在,我想从我的数据库里做一个大致的搜索。最好的方法是什么?
例如,我在数据库中存储加密的名称,但我希望能够搜索具有特定名称的行。

暂无答案!

目前还没有任何答案,快来回答吧!

相关问题