PHP数组加密解密算法

数组加密解密算法,在这里我用来加密cookie。

功能:1、可以对数组进行加密,自己可设置加密种子,并生成随机数字和数组生成的字符串混合加密。最后生成加密后的字符串。

        2、逆向解密加密后的字符串。

优点:加密后生成的字符串也是随机的,每次都不同。

  • 一、算法:
class _setcookie{
	//加密函数(参数:数组,返回值:字符串)
	public static $key_t = "sjiofssdsfd";//设置加密种子
	public static function encrypt($cookie_array){
		$txt = serialize($cookie_array);
		srand();//生成随机数
		$encrypt_key = md5(rand(0,10000));//从0到10000取一个随机数
		$ctr = 0;
		$tmp = '';
		for($i = 0;$i < strlen($txt);$i++){
			$ctr = $ctr == strlen($encrypt_key) ? 0 : $ctr;
			$tmp .= $encrypt_key[$ctr].($txt[$i] ^ $encrypt_key[$ctr++]);
		}
		return base64_encode(_setcookie::key($tmp,_setcookie::$key_t));
	}
	
	//解密函数(参数:字符串,返回值:数组)
	public static function decrypt($txt){
		$txt = _setcookie::key(base64_decode($txt), _setcookie::$key_t);
		$tmp = '';
		for($i = 0;$i < strlen($txt); $i++) {
			$md5 = $txt[$i];
			$tmp .= $txt[++$i] ^ $md5;
		}
		$tmp_t = unserialize($tmp);
		return $tmp_t;
	}
	
	public static function key($txt,$encrypt_key){
		$encrypt_key = md5($encrypt_key);
		$ctr = 0;
		$tmp = '';
		for($i = 0; $i < strlen($txt); $i++) {
			$ctr = $ctr == strlen($encrypt_key) ? 0 : $ctr;
			$tmp .= $txt[$i] ^ $encrypt_key[$ctr++];
		}
		return $tmp;
	}
}
  • 二、测试:
$test=array(
		"realname" => "小明",
		"username" => "xiaoming",
		"groupid" => "1",
		"password" => "a23bsdfsdfsdf",
		"lastlogindate"=> "2013-11-01",
		"lastloginIP" => "10.1.1.159"
		);
$en_a=_setcookie::encrypt($test);
//打印加密后的字符串 echo $en_a; echo "<br/>";
$test_base64 = base64_decode($en_a);
//打印用base64解密后的字符串,测试用 echo $test_base64; echo "<br/>"; $de_a=_setcookie::decrypt($en_a);
//打印解密后的字符串 print_r($de_a);

  

 

 

转载于:https://www.cnblogs.com/fremcode/p/3437295.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值