/*

* 类中,功能部分功能没有提炼,还需进一步修改

*/

class Mymcrypt {

// 盐值 [字符串]

public $key = "mrdede.com";

function __construct($salt=''){

$this->salt = $salt; // [string] 盐值 可以为空

}

// 加密

public function do_mencrypt($input)

{

// $key = substr(md5($this->key), 0, 24);

// $td = mcrypt_module_open('des', '', 'ecb', '');

// $td = mcrypt_module_open(MCRYPT_RIJNDAEL_128, '', MCRYPT_MODE_ECB, '');

$td = mcrypt_module_open(MCRYPT_RIJNDAEL_256, '', MCRYPT_MODE_ECB, '');

$iv = mcrypt_create_iv(mcrypt_enc_get_iv_size($td), MCRYPT_RAND);

//没有做key size设定

$key_size = mcrypt_enc_get_key_size($td); //返回所支持的最大的密钥长度(以字节计算)

// echo "==== $key_size ==="; // 32

$subkey = substr(md5(md5($this->key).$this->salt), 0,$key_size);//对key复杂处理,并设置长度

mcrypt_generic_init($td, $subkey, $iv);

$encrypted_data = mcrypt_generic($td, $input);

mcrypt_generic_deinit($td);

mcrypt_module_close($td);

// return trim(chop($this->base64url_encode($encrypted_data)));

return $encrypted_data;

}

// 解密

//$input - stuff to decrypt

public function do_mdecrypt($input)

{

// $key = substr(md5($this->key), 0, 24);

// $td = mcrypt_module_open('des', '', 'ecb', '');

// $td = mcrypt_module_open(MCRYPT_RIJNDAEL_128, '', MCRYPT_MODE_ECB, '');

$td = mcrypt_module_open(MCRYPT_RIJNDAEL_256, '', MCRYPT_MODE_ECB, '');

$iv = mcrypt_create_iv(mcrypt_enc_get_iv_size($td), MCRYPT_RAND);

//没有做key size设定

$key_size = mcrypt_enc_get_key_size($td); //返回支持的最大的密钥长度(以字节计)也可自己设定比如24

$subkey = substr(md5(md5($this->key).$this->salt), 0,$key_size);////对key复杂处理,并设置长度

mcrypt_generic_init($td, $subkey, $iv);

$decrypted_data = mdecrypt_generic($td, $input);

mcrypt_generic_deinit($td);

mcrypt_module_close($td);

// return trim(chop($decrypted_data));

return $decrypted_data;

}

// base64在url传递过程中需要注意的

// 把base64加密后在url传输,会把“+“,”/”分别替换为”-”,”_”,以及会把末尾的等号“=”去掉。

// 另外base64加密后的长度必然是4的倍数,所以可以根据这个还原“=”号

function base64url_encode($data) {

return rtrim(strtr(base64_encode($data), '+/', '-_'), '=');

// return $data; //不处理会乱码

// return base64_encode($data);

}

function base64url_decode($data) {

return base64_decode(str_pad(strtr($data, '-_', '+/'), strlen($data) % 4, '=', STR_PAD_RIGHT));

}

}

// 用法

$myMcrypt = new Mymcrypt();

$data = 'PD867H4V9J6B';

echo "测试的数据:$data
";

$value = $myMcrypt->do_mencrypt($data); // 加密

// $value = $myMcrypt->base64url_encode($value); // 编码 可以使用特殊处理过的base64_encode

echo "加密后未编码的:$value
"; // 加密后未编码的

$value = base64_encode($value); // 编码 方便在网页显示

$value = trim($value); // 有时后面会带很多预定于字符串

echo "$value
长度:".strlen($value)."
";

// $value = $myMcrypt->base64url_decode($value); // 解码 可以使用特殊处理过的base64_decode

$value = base64_decode($value); // 解码

echo "解码后未解密的:$value
"; // 解码后未解密的

$value = $myMcrypt->do_mdecrypt($value);// 解密

$value = trim($value);

echo "$value
长度:".strlen($value)."
";

Logo

欢迎加入 MCP 技术社区!与志同道合者携手前行,一同解锁 MCP 技术的无限可能!

更多推荐