mcrypt如何对已加密的字符串解密?
我在准备使用mcrypt加密/解密用户密码, 但是我发现一个问题,
下面是代码, 但是根本不能解密~~~
问题出在生成$iv上, 两次的$iv不同导致加密后的字符串无法正常解密。
由于这两个方法一个在注册时调用, 一个在登录时调用, 所以没有办法共享$iv.
这得怎么啊?
我google出来的结果都是使用同一个$iv进行加密/解密的~~~
<code> private function encryptPassword($password) { if ( self::PASSWORD_MAX_LENGTH 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; } </code>
回复内容:
我在准备使用mcrypt加密/解密用户密码, 但是我发现一个问题,
下面是代码, 但是根本不能解密~~~
问题出在生成$iv上, 两次的$iv不同导致加密后的字符串无法正常解密。
由于这两个方法一个在注册时调用, 一个在登录时调用, 所以没有办法共享$iv.
这得怎么啊?
我google出来的结果都是使用同一个$iv进行加密/解密的~~~
<code> private function encryptPassword($password) { if ( self::PASSWORD_MAX_LENGTH 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; } </code>
初始化向量iv是不需要每次都重新生成的,你可以保存下来,拿你的场合来说,你可以把它和密文一起存储,这样就可以解决这个问题了。你可以读php的官方文档的解释 http://php.net/manual/zh/function.mcrypt-create-iv.php

Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

AI Hentai Generator
Generate AI Hentai for free.

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Hot Topics

In this chapter, we will understand the Environment Variables, General Configuration, Database Configuration and Email Configuration in CakePHP.

PHP 8.4 brings several new features, security improvements, and performance improvements with healthy amounts of feature deprecations and removals. This guide explains how to install PHP 8.4 or upgrade to PHP 8.4 on Ubuntu, Debian, or their derivati

To work with date and time in cakephp4, we are going to make use of the available FrozenTime class.

To work on file upload we are going to use the form helper. Here, is an example for file upload.

In this chapter, we are going to learn the following topics related to routing ?

CakePHP is an open-source framework for PHP. It is intended to make developing, deploying and maintaining applications much easier. CakePHP is based on a MVC-like architecture that is both powerful and easy to grasp. Models, Views, and Controllers gu

Validator can be created by adding the following two lines in the controller.

Visual Studio Code, also known as VS Code, is a free source code editor — or integrated development environment (IDE) — available for all major operating systems. With a large collection of extensions for many programming languages, VS Code can be c
