2009
Nov
07
在做项目时经常会遇到加密与解密,例如用户注册后会发一封邮件到邮箱,点击邮件中的链接激活账号,这是就需要用到加密与解密。在加密与解密时经常会遇到一个问题,就是密匙中可能会有加号,在解密的时候就解密不了,原因是遇到加号就相当于密匙结束了,下面这段加密代码,经过修改后已完美解决了这个问题:
/*加密函数内部调用函数*/
function keyED($txt,$encrypt_key) {
$encrypt_key = md5($encrypt_key);
$ctr=0;
$tmp = "";
for ($i=0;$i<strlen($txt);$i++) {
if ($ctr==strlen($encrypt_key)) $ctr=0;
$tmp.= substr($txt,$i,1) ^ substr($encrypt_key,$ctr,1);
$ctr++;
}
return $tmp;
}
/*发送邮件中连接地址的加密函数*/
function inner_DYEncrypt( $encryptstr ){
return urlencode(inner_DYEncrypt_subfun($encryptstr));
}
function inner_DYEncrypt_subfun($encryptstr){
srand((double)microtime()*1000000);
$encrypt_key = md5(rand(0,32000));
$ctr=0; $tmpstr = "";
for ($i=0;$i<strlen($encryptstr);$i++){
if ($ctr==strlen($encrypt_key)) $ctr=0;
$tmpstr.= substr($encrypt_key,$ctr,1) .
(substr($encryptstr,$i,1) ^ substr($encrypt_key,$ctr,1));
$ctr++;
}
$returninfo = base64_encode(keyED($tmpstr,ENCRYPTKEY));
if (strrpos($returninfo,"/") or strrpos($returninfo,'') or strrpos($returninfo,'+'))
return inner_DYEncrypt_subfun( $encryptstr );
return $returninfo;
}
/*发送邮件中连接地址的解密函数*/
function inner_DYDecrypt( $decryptstr ){
$decryptstr = urldecode($decryptstr);
$decryptstr = keyED(base64_decode($decryptstr),ENCRYPTKEY);
$tmpstr = "";
for ($i=0;$i<strlen($decryptstr);$i++){
$md5 = substr($decryptstr,$i,1);
$i++;
$tmpstr.= (substr($decryptstr,$i,1) ^ $md5);
}
return $tmpstr;
}
/*演示*/
$key = "rdid=5135"; //待加密的字符串
echo "待加密的字符串:".$key."";
$key = inner_DYEncrypt($key);
echo "加密后的字符串:".$key."";
echo "解密后的字符串:".inner_DYDecrypt($key);
?>本站原创,转载请标明:来自追梦博客(http://www.wuleilei.com/)
相关文章
PHP经典乱码“锘”字与解决办法 (2009-06-08)
用thinkphp重新把博客写一遍 (2009-08-02)
php换行转换函数nl2br() (2009-11-09)
评论嵌套原理 - 博客已支持评论嵌套 (2010-04-24)
SQLite 一款不错的数据库 (2010-05-22)
一个很好用的PHP生成RSS的类:FeedCreator (2010-06-26)
PHP配置了SQLite扩展却无法使用SQLite的解决方法 (2010-08-16)
PHP基础易混淆函数比较 (2010-10-25)
PHP二维数组按照一个字段排序 (2010-12-28)
PHP无刷新上传文件原理 (2010-12-10)
看看他们的脚印
晚上和爸妈吃个饭。 (2月6日)
装修好累哟
(2月4日)
《斯巴达克斯:复仇》 (2月3日)
白
JankoAtWarpSpeed对...