php cookie 加密解密,PHP实现cookie的加密与解密函数方法

本文介绍了一种使用PHP实现的Cookie加密与解密方法,旨在提高网站的安全性。通过定义加密和解密函数,利用MD5和自定义字符集进行混合加密,确保了数据在Cookie中传输过程中的安全性。加密过程中,时间戳被加入以增加解密时的数据有效性检查。
摘要由CSDN通过智能技术生成

PHP实现cookie的加密与解密函数方法

通过加密cookie可以使网站的安全性提高<?php

/**

* 加密函数

* @param string $txt 需要加密的字符串

* @param string $key 密钥

* @return string 返回加密结果

*/

function encrypt($txt, $key = ''){

if (empty($txt)) return $txt;

if (empty($key)) $key = md5(MD5_KEY);

$chars = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_.";

$ikey ="-x6g6ZWm2G9g_vr0Bo.pOq3kRIxsZ6rm";

$nh1 = rand(0,64);

$nh2 = rand(0,64);

$nh3 = rand(0,64);

$ch1 = $chars{$nh1};

$ch2 = $chars{$nh2};

$ch3 = $chars{$nh3};

$nhnum = $nh1 + $nh2 + $nh3;

$knum = 0;$i = 0;

while(isset($key{$i})) $knum +=ord($key{$i++});

$mdKey = substr(md5(md5(md5($key.$ch1).$ch2.$ikey).$ch3),$nhnum%8,$knum%8 + 16);

$txt = base64_encode(time().'_'.$txt);

$txt = str_replace(array('+','/','='),array('-','_','.'),$txt);

$tmp = '';

$j=0;$k = 0;

$tlen = strlen($txt);

$klen = strlen($mdKey);

for ($i=0; $i

$k = $k == $klen ? 0 : $k;

$j = ($nhnum+strpos($chars,$txt{$i})+ord($mdKey{$k++}))%64;

$tmp .= $chars{$j};

}

$tmplen = strlen($tmp);

$tmp = substr_replace($tmp,$ch3,$nh2 % ++$tmplen,0);

$tmp = substr_replace($tmp,$ch2,$nh1 % ++$tmplen,0);

$tmp = substr_replace($tmp,$ch1,$knum % ++$tmplen,0);

return $tmp;

}

/**

* 解密函数

* @param string $txt 需要解密的字符串

* @param string $key 密匙

* @return string 字符串类型的返回结果

*/

function decrypt($txt, $key = '', $ttl = 0){

if (empty($txt)) return $txt;

if (empty($key)) $key = md5(MD5_KEY);

$chars = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_.";

$ikey ="-x6g6ZWm2G9g_vr0Bo.pOq3kRIxsZ6rm";

$knum = 0;$i = 0;

$tlen = @strlen($txt);

while(isset($key{$i})) $knum +=ord($key{$i++});

$ch1 = @$txt{$knum % $tlen};

$nh1 = strpos($chars,$ch1);

$txt = @substr_replace($txt,'',$knum % $tlen--,1);

$ch2 = @$txt{$nh1 % $tlen};

$nh2 = @strpos($chars,$ch2);

$txt = @substr_replace($txt,'',$nh1 % $tlen--,1);

$ch3 = @$txt{$nh2 % $tlen};

$nh3 = @strpos($chars,$ch3);

$txt = @substr_replace($txt,'',$nh2 % $tlen--,1);

$nhnum = $nh1 + $nh2 + $nh3;

$mdKey = substr(md5(md5(md5($key.$ch1).$ch2.$ikey).$ch3),$nhnum % 8,$knum % 8 + 16);

$tmp = '';

$j=0; $k = 0;

$tlen = @strlen($txt);

$klen = @strlen($mdKey);

for ($i=0; $i

$k = $k == $klen ? 0 : $k;

$j = strpos($chars,$txt{$i})-$nhnum - ord($mdKey{$k++});

while ($j<0) $j+=64;

$tmp .= $chars{$j};

}

$tmp = str_replace(array('-','_','.'),array('+','/','='),$tmp);

$tmp = trim(base64_decode($tmp));

if (preg_match("/\d{10}_/s",substr($tmp,0,11))){

if ($ttl > 0 && (time() - substr($tmp,0,11) > $ttl)){

$tmp = null;

}else{

$tmp = substr($tmp,11);

}

}

return $tmp;

}

echo encrypt('cmwl520','cmwl').'
';

echo decrypt('HPU_qNbbdE9ZxcFvqhbQJnJTAwY', 'cmwl');

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值