简易的加密解密方法

	/**
	 * @todo 解密
	 * @param String $text 加密后的密码
	 * @return String $tmp 原始密码
	 */
	function decrypt($text){
		$encrypt_key = 'ggbound';
		$text = __key(base64_decode($text),$encrypt_key);
		$tmp = '';
		for($i = 0;$i < strlen($text); $i++) {
			$md5 = $text[$i];
			$tmp .= $text[++$i] ^ $md5;
		}
		return $tmp;
	}
	
	/**
	 * @todo 加密
	 * @param String $text 原始密码
	 * @return String base64_encode 加密后的字符串
	 */
	function encrypt($text){
		$encrypt_key = 'ggbound';
		$ctr = 0;
		$tmp = '';
		for($i = 0;$i<strlen($text);$i++) {
			$ctr = $ctr == strlen($encrypt_key) ? 0 : $ctr;
			$tmp .= $encrypt_key[$ctr].($text[$i]^$encrypt_key[$ctr++]);
		}
		return base64_encode(__key($tmp,$encrypt_key));
	}
	
	/**
	 * @todo init key
	 * @param String $text
	 * @param String $encrypt_key
	 * @return String $tmp
	 */
	function __key($text,$encrypt_key){
		$encrypt_key = md5($encrypt_key);
		$ctr = 0;
		$tmp = '';
		for($i = 0; $i < strlen($text); $i++) {
			$ctr = $ctr == strlen($encrypt_key) ? 0 : $ctr;
			$tmp .= $text[$i] ^ $encrypt_key[$ctr++];
		}
		return $tmp;
	}
	
	$text = '12345';
	echo encrypt($text);
	echo '<br />';
	echo decrypt(encrypt($text));
这个加密解密的方法不支持空字符、数组、中文等加密,目前支持不为空的字符串(数字+字母+符号)进行加密解密。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值