mcrypt如何对已加密的字符串解密?

php中文网
发布: 2016-06-06 20:31:13
原创
1420人浏览过

我在准备使用mcrypt加密/解密用户密码, 但是我发现一个问题,
下面是代码, 但是根本不能解密~~~

问题出在生成$iv上, 两次的$iv不同导致加密后的字符串无法正常解密。
由于这两个方法一个在注册时调用, 一个在登录时调用, 所以没有办法共享$iv.

这得怎么啊?

我google出来的结果都是使用同一个$iv进行加密/解密的~~~

Brev AI
Brev AI

Brev.ai:搭载Suno AI V3.5技术的免费AI音乐生成器

Brev AI 437
查看详情 Brev AI
    private function encryptPassword($password) {
        if ( self::PASSWORD_MAX_LENGTH < strlen($password) ) {
            $password = substr($password, 0, self::PASSWORD_MAX_LENGTH);
        }

        /* @var $accountService AccountService */
        $accountService = X::system()->getServiceManager()->get(AccountService::getServiceName());
        $passwordSecret = $accountService->getConfiguration()->get('password_secret');

        $cipherAlg = MCRYPT_RIJNDAEL_128;
        $iv = mcrypt_create_iv(mcrypt_get_iv_size($cipherAlg,MCRYPT_MODE_ECB), MCRYPT_RAND);
        $encryptedPassword = mcrypt_encrypt($cipherAlg,$passwordSecret,$password, MCRYPT_MODE_CBC, $iv);

        $encryptedPassword = base64_encode($encryptedPassword);
        return $encryptedPassword;
    }

    /**
     * @param unknown $encryptedPassword
     */
    private function decryptPassword($encryptedPassword) {
        /* @var $accountService AccountService */
        $accountService = X::system()->getServiceManager()->get(AccountService::getServiceName());
        $passwordSecret = $accountService->getConfiguration()->get('password_secret');

        $cipherAlg = MCRYPT_RIJNDAEL_128;
        $iv = mcrypt_create_iv(mcrypt_get_iv_size($cipherAlg,MCRYPT_MODE_ECB), MCRYPT_RAND);


        $encryptedPassword = base64_decode($encryptedPassword);
        $decryptPassword = mcrypt_decrypt($cipherAlg, $passwordSecret, $encryptedPassword, MCRYPT_MODE_CBC, $iv);
        return $decryptPassword;
    }
登录后复制

回复内容:

我在准备使用mcrypt加密/解密用户密码, 但是我发现一个问题,
下面是代码, 但是根本不能解密~~~

问题出在生成$iv上, 两次的$iv不同导致加密后的字符串无法正常解密。
由于这两个方法一个在注册时调用, 一个在登录时调用, 所以没有办法共享$iv.

这得怎么啊?

我google出来的结果都是使用同一个$iv进行加密/解密的~~~

    private function encryptPassword($password) {
        if ( self::PASSWORD_MAX_LENGTH < strlen($password) ) {
            $password = substr($password, 0, self::PASSWORD_MAX_LENGTH);
        }

        /* @var $accountService AccountService */
        $accountService = X::system()->getServiceManager()->get(AccountService::getServiceName());
        $passwordSecret = $accountService->getConfiguration()->get('password_secret');

        $cipherAlg = MCRYPT_RIJNDAEL_128;
        $iv = mcrypt_create_iv(mcrypt_get_iv_size($cipherAlg,MCRYPT_MODE_ECB), MCRYPT_RAND);
        $encryptedPassword = mcrypt_encrypt($cipherAlg,$passwordSecret,$password, MCRYPT_MODE_CBC, $iv);

        $encryptedPassword = base64_encode($encryptedPassword);
        return $encryptedPassword;
    }

    /**
     * @param unknown $encryptedPassword
     */
    private function decryptPassword($encryptedPassword) {
        /* @var $accountService AccountService */
        $accountService = X::system()->getServiceManager()->get(AccountService::getServiceName());
        $passwordSecret = $accountService->getConfiguration()->get('password_secret');

        $cipherAlg = MCRYPT_RIJNDAEL_128;
        $iv = mcrypt_create_iv(mcrypt_get_iv_size($cipherAlg,MCRYPT_MODE_ECB), MCRYPT_RAND);


        $encryptedPassword = base64_decode($encryptedPassword);
        $decryptPassword = mcrypt_decrypt($cipherAlg, $passwordSecret, $encryptedPassword, MCRYPT_MODE_CBC, $iv);
        return $decryptPassword;
    }
登录后复制

初始化向量iv是不需要每次都重新生成的,你可以保存下来,拿你的场合来说,你可以把它和密文一起存储,这样就可以解决这个问题了。你可以读php的官方文档的解释 http://php.net/manual/zh/function.mcrypt-create-iv.php

相关标签:
php
最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号