0

我是加密新手并利用这个类来获取令牌,有人可以帮助我在参考资料、视频教程等的帮助下理解这两个函数的情况,以便更深入地理解。目的是使用相同的技术来理解和实现其他语言。

class Crypt {

public static function encrypt($data, $secret) {
    $iv_size = mcrypt_get_iv_size(MCRYPT_RIJNDAEL_128, MCRYPT_MODE_CBC);
    $iv = mcrypt_create_iv($iv_size, MCRYPT_RAND);
    $key = pack('H*', $secret);
    return base64_encode($iv . mcrypt_encrypt(MCRYPT_RIJNDAEL_128, $key, $data, MCRYPT_MODE_CBC, $iv));
}

public static function decrypt($data, $secret) {
    $data = base64_decode($data);
    $iv_size = mcrypt_get_iv_size(MCRYPT_RIJNDAEL_128, MCRYPT_MODE_CBC);
    $iv = substr($data, 0, $iv_size);
    $data = substr($data, $iv_size);
    $key = pack('H*', $secret);
    return trim(mcrypt_decrypt(MCRYPT_RIJNDAEL_128, $key, $data, MCRYPT_MODE_CBC, $iv), chr(0));
}
}

谢谢

4

1 回答 1

0

以及使用相同技术以其他语言实现

我不信 ,)

不是一个简单的话题。就像您发布的那样,您将不得不深入研究不同的密码和加密,尤其是 RIJNDAEL_128 和 CBC。

如果您想了解 rinjndael,请查找AES(高级加密标准)

SPEC 您可以在以下网址找到官方规范:http ://csrc.nist.gov/publications/fips/fips197/fips-197.pdf

本书 这是 Christof Paar 和 Jan Pelzl 的加密教科书中的 AES capther: http ://wiki.crypto.rub.de/Buch/download/Understanding-Cryptography-Chapter4.pdf

教程

视频

动画/演示

PHP 手册 - 扩展 mCrypt

代码

于 2014-10-18T14:55:52.753 回答