Aes CBC加密

 1 <?php
 2 namespace app\components;
 3 use yii;
 4 class Aes
 5 {
 6     /**
 7      * This was AES-128 / CBC / PKCS5Padding
 8      * return base64_encode string
 9      * @param string $plaintext
10      * @param string $key
11      * @return string
12      */
13     public static function AesEncrypt($plaintext,$key = null)
14     {
15         $plaintext = trim($plaintext);
16         if ($plaintext == '') return '';
17         $size = mcrypt_get_block_size(MCRYPT_RIJNDAEL_128, MCRYPT_MODE_CBC);
18 
19         //PKCS5Padding
20         $padding = $size - strlen($plaintext) % $size;
21         // 添加Padding
22         $plaintext .= str_repeat(chr($padding), $padding);
23 
24 
25         $module = mcrypt_module_open(MCRYPT_RIJNDAEL_128, '', MCRYPT_MODE_CBC, '');
26         $key=self::substr($key, 0, mcrypt_enc_get_key_size($module));
27         $iv = $key;
28         // str_repeat($key, $size);
29         /* Intialize encryption */
30         mcrypt_generic_init($module, $key, $iv);
31 
32 
33         /* Encrypt data */
34         $encrypted = mcrypt_generic($module, $plaintext);
35         /* Terminate encryption handler */
36         mcrypt_generic_deinit($module);
37         mcrypt_module_close($module);
38         return base64_encode($encrypted);
39     }
40     /**
41      * Returns the length of the given string.
42      * If available uses the multibyte string function mb_strlen.
43      * @param string $string the string being measured for length
44      * @return integer the length of the string
45      */
46     private static function strlen($string)
47     {
48         return extension_loaded('mbstring') ? mb_strlen($string,'8bit') : strlen($string);
49     }
50 
51 
52     /**
53      * Returns the portion of string specified by the start and length parameters.
54      * If available uses the multibyte string function mb_substr
55      * @param string $string the input string. Must be one character or longer.
56      * @param integer $start the starting position
57      * @param integer $length the desired portion length
58      * @return string the extracted part of string, or FALSE on failure or an empty string.
59      */
60     private static function substr($string,$start,$length)
61     {
62         return extension_loaded('mbstring') ? mb_substr($string,$start,$length,'8bit') : substr($string,$start,$length);
63     }
64     /**
65      * This was AES-128 / CBC / PKCS5Padding
66      * @param string $encrypted     base64_encode encrypted string
67      * @param string $key
68      * @throws CException
69      * @return string
70      */
71     public static function AesDecrypt($encrypted, $key = null)
72     {
73         if ($encrypted == '') return '';
74         $ciphertext_dec = base64_decode($encrypted);
75         $module = mcrypt_module_open(MCRYPT_RIJNDAEL_128, '', MCRYPT_MODE_CBC, '');
76         $key=self::substr($key, 0, mcrypt_enc_get_key_size($module));
77         $iv = $key;
78         // str_repeat($key, 16);    //解密的初始化向量要和加密時同樣。
79         /* Initialize encryption module for decryption */
80         mcrypt_generic_init($module, $key, $iv);
81 
82 
83         /* Decrypt encrypted string */
84         $decrypted = mdecrypt_generic($module, $ciphertext_dec);
85 
86         /* Terminate decryption handle and close module */
87         mcrypt_generic_deinit($module);
88         mcrypt_module_close($module);
89         // echo $decrypted;die;
90         //$a = rtrim($decrypted,"\0");
91         return rtrim($decrypted,"\0");
92     }
93 }
相關文章
相關標籤/搜索