PHP 基于 Mcrypt 的加密解密简单类

最近的一个项目项目中需要对 Cookie 加密,所以使用到了 Mcrypt 的方法进行加密解密的工作,于是我就整理成一个简单的类,以后直接简单调用类实现即可。

Mcrypt 介绍

Mcrypt 是 PHP 的一个扩展,完成了常用加密算法的封装,mcrypt 库提供了对多种块算法的支持, 包括:DES,TripleDES,Blowfish (默认), 3-WAY,SAFER-SK64,SAFER-SK128,TWOFISH,TEA,RC2 以及 GOST,并且支持 CBC,OFB,CFB 和 ECB 密码模式。 甚至它还支持诸如 RC6 和 IDEA 这两种“非免费”的算法。

可以使用 mcrypt_list_modes() 函数列出当前环境支持的模式,以及使用 mcrypt_list_algorithms() 列出当前环境支持的算法。

简单的 Mcrypt 的加密解密类

下面创建一个简单的类,默认使用 RIJNDAEL_256 算法和 ECB 模式,当然也可以传递其他的算法和模式进去。

<br />
Class WPJAM_Mcrypt{<br />
	private $key;<br />
	private $algorithm				= MCRYPT_RIJNDAEL_256;<br />
	private $algorithm_directory	= '';<br />
	private $mode 					= MCRYPT_MODE_ECB;<br />
	private $mode_directory			= '';</p>
<p>	public function __construct($key, $args=array()){<br />
		$this->key					= $key;<br />
		$this->algorithm			= isset($args['$algorithm'])?$args['$algorithm']:$this->algorithm;<br />
		$this->algorithm_directory	= isset($args['$algorithm_directory'])?$args['$algorithm_directory']:$this->algorithm_directory;<br />
		$this->mode					= isset($args['$mode'])?$args['$mode']:$this->mode;<br />
		$this->mode_directory		= isset($args['$mode_directory'])?$args['$mode_directory']:$this->mode_directory;<br />
	}</p>
<p>	public function encrypt($text){<br />
		$module		= mcrypt_module_open($this->algorithm, $this->algorithm_directory, $this->mode, $this->mode_directory);<br />
		$iv_size	= mcrypt_enc_get_iv_size($module);<br />
		$iv			= mcrypt_create_iv($iv_size, MCRYPT_RAND);</p>
<p>		mcrypt_generic_init($module, $this->key, $iv);</p>
<p>		$encrypted_text	= mcrypt_generic($module, $text);<br />
		mcrypt_generic_deinit($module);<br />
		mcrypt_module_close($module);<br />
		return trim(base64_encode($encrypted_text));<br />
	}</p>
<p>	public function decrypt($encrypted_text){<br />
		$encrypted_text	= base64_decode($encrypted_text);</p>
<p>		$module		= mcrypt_module_open($this->algorithm, $this->algorithm_directory, $this->mode, $this->mode_directory);<br />
		$iv_size	= mcrypt_enc_get_iv_size($module);<br />
		$iv			= mcrypt_create_iv($iv_size, MCRYPT_RAND);</p>
<p>		mcrypt_generic_init($module, $this->key, $iv);</p>
<p>		$decrypted_text	= mdecrypt_generic($module, $encrypted_text);<br />
		return trim($decrypted_text);<br />
	}<br />
}<br />

使用方法非常简单:

<br />
//首先创建类<br />
$wpjam_mcrypt	= new WPJAM_Mcrypt('t12d3uBDDVy9eC836r76VKlBvtEFzizz');</p>
<p>$plain_text	= '要加密的文字';<br />
$encrypted_text	= $wpjam_mcrypt->encrypt($plgin_text); // 加密</p>
<p>$decrypted_text	= $wpjam_mcrypt->decrypted($encrypted_text); // 解密<br />

热门文章