PHP DES加解密
程序员文章站
2022-04-19 10:35:42
test.php测试文件 Des.php TripleDES.php ......
test.php测试文件
<?php require_once('des.php'); $des = new des(); $data['a'] = 'a'; $data['b'] = 'b'; $conf = ['appkey'=>'abcdefghijklmnopqrstuvwx','secretcode'=>'abcdefgh']; $encode = $des->encode($data, $conf); print_r($encode); echo "<br>"; $decode = $des->decode($encode,$conf); print_r($decode); ?>
des.php
<?php require_once('tripledes.php'); class des { public static function encode($data, $configkey) { $tripledes = new tripledes(); if (is_array($data)) { $data = json_encode($data); } return $tripledes->encode($data, $configkey["appkey"], $configkey["secretcode"]); } public static function decode($data, $configkey) { $tripledes = new tripledes(); return $tripledes->decode($data, $configkey["appkey"], $configkey["secretcode"]); } public static function encodearr($data, $configkey) { $data = json_encode($data); return self::encode($data, $configkey); } public static function decodearr($data, $configkey) { $res = self::decode($data, $configkey); return json_decode($res,true); } }
tripledes.php
<?php class tripledes { public static function genivparameter() { return mcrypt_create_iv(mcrypt_get_iv_size(mcrypt_tripledes, mcrypt_mode_cbc), mcrypt_rand); } private static function pkcs5pad($text, $blocksize) { $pad = $blocksize - (strlen($text) % $blocksize); // in php, strlen returns the bytes of $text return $text . str_repeat(chr($pad), $pad); } private static function pkcs5unpad($text) { $pad = ord($text{strlen($text) - 1}); if ($pad > strlen($text)) return false; if (strspn($text, chr($pad), strlen($text) - $pad) != $pad) return false; return substr($text, 0, -1 * $pad); } public static function encrypttext($plain_text, $key, $iv) { $padded = tripledes::pkcs5pad($plain_text, mcrypt_get_block_size(mcrypt_tripledes, mcrypt_mode_cbc)); return mcrypt_encrypt(mcrypt_tripledes, $key, $padded, mcrypt_mode_cbc, $iv); } public static function decrypttext($cipher_text, $key, $iv) { if(function_exists('mcrypt_decrypt')){ $plain_text = mcrypt_decrypt(mcrypt_tripledes, $key, $cipher_text, mcrypt_mode_cbc, $iv); }else{ $plain_text = openssl_decrypt($cipher_text, 'des-ede3-cbc',$key, openssl_no_padding,$iv); } return tripledes::pkcs5unpad($plain_text); } public static function decode($cipher_text, $key, $iv) { $cipher_text = base64_decode($cipher_text); $cipher_text = tripledes::decrypttext($cipher_text, $key, $iv); return $cipher_text; } public static function encode($cipher_text, $key, $iv) { $cipher_text = tripledes::encrypttext($cipher_text, $key, $iv); return base64_encode($cipher_text); } }