如果您登记入住,\app\code\core\Mage\Customer\Model\Customer.php
您会发现类似这样的内容(靠近 430 行):
/**
* Encrypt password
*
* @param string $password
* @return string
*/
public function encryptPassword($password)
{
return Mage::helper('core')->encrypt($password);
}
helper('core')
是_\app\code\core\Mage\Core\Helper\Data.php
在\app\code\core\Mage\Core\Helper\Data.php
中,您会发现:
/**
* Encrypt data using application key
*
* @param string $data
* @return string
*/
public function encrypt($data)
{
if (!Mage::isInstalled()) {
return $data;
}
return $this->getEncryptor()->encrypt($data);
}
功能getEncryptor()
是:
/**
* @return Mage_Core_Model_Encryption
*/
public function getEncryptor()
{
if ($this->_encryptor === null) {
$encryptionModel = (string)Mage::getConfig()->getNode(self::XML_PATH_ENCRYPTION_MODEL);
if ($encryptionModel) {
$this->_encryptor = new $encryptionModel;
} else {
$this->_encryptor = Mage::getModel('core/encryption');
}
$this->_encryptor->setHelper($this);
}
return $this->_encryptor;
}
$this->_encryptor
在\app\code\core\Mage\Core\Model\Encryption.php
此文件中,您可以找到:
/**
* Encrypt a string
*
* @param string $data
* @return string
*/
public function encrypt($data)
{
return base64_encode($this->_getCrypt()->encrypt((string)$data));
}
和
/**
* Instantiate crypt model
*
* @param string $key
* @return Varien_Crypt_Mcrypt
*/
protected function _getCrypt($key = null)
{
if (!$this->_crypt) {
if (null === $key) {
$key = (string)Mage::getConfig()->getNode('global/crypt/key');
}
$this->_crypt = Varien_Crypt::factory()->init($key);
}
return $this->_crypt;
}
(string)Mage::getConfig()->getNode('global/crypt/key');
在/app/etc/local.xml
文件中。
您的变量$hashed_password
通过最后一种方法。
你的变量$hashInput
也通过那里?
所以,你可以改变你的checkPassword()
功能:
$hashInput = md5($passwordInput . $salt);
至
$hashInput = encryptPassword($passwordInput);
因此,$hashInput
并将$hashed_password
遵循相同的方式。