php - 函数加密AES-256-CBC,搜索mysql

标签 php mysql encryption

我使用 PHP 和 MySQL,并在 PHP 中使用此函数以加密形式输入数据:

function encrypt_decrypt($action, $string) {
    $output = false;

    $encrypt_method = "AES-256-CBC";
    $secret_key = 'This is my secret key';
    $secret_iv = 'This is my secret iv';

    // hash
    $key = hash('sha256', $secret_key);

    // iv - encrypt method AES-256-CBC expects 16 bytes - else you will get a warning
    $iv = substr(hash('sha256', $secret_iv), 0, 16);

    if( $action == 'encrypt' ) {
        $output = openssl_encrypt($string, $encrypt_method, $key, 0, $iv);
        $output = base64_encode($output);
    }
    else if( $action == 'decrypt' ){
        $output = openssl_decrypt(base64_decode($string), $encrypt_method, $key, 0, $iv);
    }

    return $output;
}

最后我遇到了一个大问题。

我需要查表,需要用到MySQL的LIKE函数。

我该怎么做?

我查找了文档,发现 MySQL 具有 AES 加密,但我完全迷失了。

这个用 PHP MySQL 写的函数是存在的,还是让它起作用?

最佳答案

当你将密文输入MySQL时,即

  • 已在 MySQL 之外加密
  • 不保留相似性(因为大多数加密不这样做)

您不能对其执行LIKE 搜索。

如果您将加密移动到数据库中,您可以执行 LIKE 搜索,但要准备好承受严重的计算性能损失:基本上,除了与LIKE 本身。

最好的选择是搜索一些重新设计的选项,让您根本不这样做。

关于php - 函数加密AES-256-CBC,搜索mysql,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28197763/

相关文章:

php - 如何知道我的数据库中的表是否已更新?

c++ - 运行 key 密码解密知道 key ?

api - 使用 SSL 的 Rest API 加密

php - 允许 php 文件仅在被另一个 PHP 文件包含时执行

php - CakePHP 实践 - 在 MVC 结构之外使用常规 PHP 文件

php - 我如何在 cakephp 1.3 中使用独立类?

android - SQLite和密码加密、解密和上传

javascript - 多提交按钮多复选框无表单jquery ajax php提交

mysql join 2表选择一行字段有多行

php - Doctrine 迁移回退