使用php扩展mcrypt实现AES加密

AES(Advanced Encryption Standard,高级加密标准)是美国联邦政府采用的一种区块加密标准。这个标准用来替代原先的DES,已经被多方分析且广为全世界所使用。Rijndael是在AES中使用的基本密码算法。

对于此算法网上流传有很多php代码实现的版本,其实php的扩展mcrypt完全支持此加密算法,不必要自己去写代码实现。先不说自己写费时费力(当然你若是想研究此加密算法,那另说),使用php代码实现的算法效率也不会太高。

mcrypt扩展在php中默认是没有的,需要自己安装配置,其方法可以在网上搜索,这里不在详述。你可以使用以下代码检查你的php环境是否支持mcrypt

[php] view plaincopy

  1. $cipher_list = mcrypt_list_algorithms();//mcrypt支持的加密算法列表
  2. $mode_list = mcrypt_list_modes();   //mcrypt支持的加密模式列表
  3. echo ‘<xmp>‘;
  4. print_r($cipher_list);
  5. print_r($mode_list);

若你的环境支持mcrypt,输出结果应该如下:

[plain] view plaincopy

  1. Array
  2. (
  3. [0] => cast-128
  4. [1] => gost
  5. [2] => rijndael-128
  6. [3] => twofish
  7. [4] => arcfour
  8. [5] => cast-256
  9. [6] => loki97
  10. [7] => rijndael-192
  11. [8] => saferplus
  12. [9] => wake
  13. [10] => blowfish-compat
  14. [11] => des
  15. [12] => rijndael-256
  16. [13] => serpent
  17. [14] => xtea
  18. [15] => blowfish
  19. [16] => enigma
  20. [17] => rc2
  21. [18] => tripledes
  22. )
  23. Array
  24. (
  25. [0] => cbc
  26. [1] => cfb
  27. [2] => ctr
  28. [3] => ecb
  29. [4] => ncfb
  30. [5] => nofb
  31. [6] => ofb
  32. [7] => stream
  33. )

其中rijndael-128,rijndael-192,rijndael-256就是AES加密,3种分别是使用不同的数据块和密钥长度进行加密。

以下是使用扩展mcrypt实现AES加密的简单示例

[php] view plaincopy

  1. /**
  2. * 利用mcrypt做AES加密解密
  3. * @author ts24<[email protected]>
  4. */
  5. abstract class AES{
  6. /**
  7. * 算法,另外还有192和256两种长度
  8. */
  9. const CIPHER = MCRYPT_RIJNDAEL_128;
  10. /**
  11. * 模式
  12. */
  13. const MODE = MCRYPT_MODE_ECB;
  14. /**
  15. * 加密
  16. * @param string $key   密钥
  17. * @param string $str   需加密的字符串
  18. * @return type
  19. */
  20. static public function encode( $key, $str ){
  21. $iv = mcrypt_create_iv(mcrypt_get_iv_size(self::CIPHER,self::MODE),MCRYPT_RAND);
  22. return mcrypt_encrypt(self::CIPHER, $key, $str, self::MODE, $iv);
  23. }
  24. /**
  25. * 解密
  26. * @param type $key
  27. * @param type $str
  28. * @return type
  29. */
  30. static public function decode( $key, $str ){
  31. $iv = mcrypt_create_iv(mcrypt_get_iv_size(self::CIPHER,self::MODE),MCRYPT_RAND);
  32. return mcrypt_decrypt(self::CIPHER, $key, $str, self::MODE, $iv);
  33. }
  34. }

使用示例:

[php] view plaincopy

  1. $str = ‘我是明文我是明文我是明文我是明文我是明文dsfdghgasdfasdddddddd‘;
  2. $key = ‘aSGJLGYEWERWRREW4567i8o‘;
  3. $str1=AES::encode($key, $str);
  4. $str2=AES::decode($key, $str1);
  5. echo ‘<xmp>‘;
  6. var_dump($str);
  7. var_dump($str1);
  8. var_dump($str2);
  9. var_dump(rtrim($str2));

输出结果

问题,不知道是什么原因,解密后的字符串(见上图),末尾还留下有不可见的填充字符,当明文刚好可以分组时则没有。

时间: 2024-08-04 20:07:27

使用php扩展mcrypt实现AES加密的相关文章

aes加密步骤

最近学了aes加密,在这写一下自己对加密过程的理解. 1.加密采用轮秘钥加密,密钥长度一般为128bit,也对应着是16个字节.128bit的秘钥长度对应的是10轮. 首先是轮秘钥的生成,即秘钥的编排方案,先选取128bit的种子秘钥,对10轮版本的aes需要11个轮秘钥,每个轮秘钥都由16个字节组成,一个字节用两个二进制数来表示.秘钥编排算法是面向字的,即一个字4字节,32bit,即每一轮要四个字.轮秘钥的并联叫做扩展秘钥,共有44个字.每个w[i]都是一个字.未完待续,先去写秘钥编排算法.

PHP安装扩展mcrypt以及相关依赖项 【PHP安装PECL扩展的方法】

一:Mcrypt简介 Mcrypt是PHP的一个扩展,完成了常用加密算法的封装.其实该扩展是对mcrypt标准类库的封装,mcrypt完成了相当多的常用加密算法,如DES, TripleDES, Blowfish (default), 3-WAY, SAFER-SK64, SAFER-SK128, TWOFISH, TEA, RC2 和 GOST加密算法,并且提供了CBC.OFB.CFB 和 ECB 四种块加密的模型. 二:安装libmcrypt依赖库 要使用该扩展,必须首先安装mcrypt标准

python AES加密解密

AES加密数据块分组长度必须为128比特,密钥长度可以是128比特.192比特.256比特中的任意一个(如果数据块及密钥长度不足时,会补齐).AES加密有很多轮的重复和变换.大致步骤如下:1.密钥扩展(KeyExpansion),2.初始轮(Initial Round),3.重复轮(Rounds),每一轮又包括:SubBytes.ShiftRows.MixColumns.AddRoundKey,4.最终轮(Final Round),最终轮没有MixColumns. AES的加密解密方法如下,其中

[PHP]AES加密----PHP服务端和Android客户端

本文采取128位AES-CBC模式加密和解密 1.首先对服务端安装mcrypt: sudo apt-get install php5-mcrypt php5-dev sudo php5enmod mcrypt sudo service apache2 restart 2.PHP服务端AES加密类代码 class MCrypt { private $iv = 'fedcba9876543210'; //初始化向量iv public $key;//AES加密的密钥key //将密钥$key传进本类

小编带你简单了解一下加密技术原理:AES加密标准

随着因特网的发展,信息传输及存储的安全问题成为影响因特网应用发展的重要因素.信息安全技术也就成为了人们研究因特网应用的新热点. 信息安全的研究包括密码理论与技术.安全协议与技术.安全体系结构理论.信息对抗理论与技术.网络安全与安全产品等领域,其中密码算法的理论与实现研究是信息安全研究的基础. AES加密标准1977年1月公布的数据加密标准DES(Data Encrption Standard)经过20年的实践应用后,现在已被认为是不可靠的.1997年1月美国国家标准和技术研究所(NIST)发布了

C语言的AES加密

C语言的AES加密 稍微封装了几个函数 方便使用 #if 1 #include <stdio.h> #include <stdlib.h> #include <string.h> /*aes_small.c*/ //辅助矩阵 /*s盒矩阵:The AES Substitution Table*/// 256 位的密匙256 位支持长度为32 个字符 static const unsigned char sbox[256]={ //static:内部变量 const:只读

信息安全-加密:AES 加密

ylbtech-信息安全-加密:AES 加密 高级加密标准(英语:Advanced Encryption Standard,缩写:AES),在密码学中又称Rijndael加密法,是美国联邦政府采用的一种区块加密标准.这个标准用来替代原先的DES,已经被多方分析且广为全世界所使用.经过五年的甄选流程,高级加密标准由美国国家标准与技术研究院(NIST)于2001年11月26日发布于FIPS PUB 197,并在2002年5月26日成为有效的标准.2006年,高级加密标准已然成为对称密钥加密中最流行的

PHP如何使用AES加密和解密

AES加密在php5的版本中使用的mcrypt_decrypt 函数,该函数已经在php7.1后弃用了,取而代之的是openssl的openssl_encrypt和openssl_decrypt,并且代码也非常精简,下面是示例代码: 1 <?php 2 3 class Aes 4 { 5 public $key = ''; 6 public $iv = ''; 7 public $method = ''; 8 9 public function __construct($config) 10 {

Linux进行AES加密每次结果都不一致并且解密失败报错

1. 现象 windows操作系统下进行"123456"的AES加密 encrypted message is below : QLNYZyjRnKF/zxAjzDt/lw== decrypted message is below : 123456 阿里云服务器,同样是"123456"的密码,每次加密结果都不一样,且不是QLNYZyjRnKF/zxAjzDt/lw==,解密是报错的 2.解决方法 经过检查之后,定位在生成KEY的方法上,如下: public stat