<?php
include "fun.php";
include "config.php";
//以下参数由合作平台提供
//sid 服务器编号 登陆后再选择服务器 参数可不填写
//uid 平台用户唯一id
//time 登录时间 时间戳
//cmfkag 成人表示 0成人 1限制
$sid = 1;
$uid = "quyou_".rand(1,10000);
$time = time();
$cmflag = 0;
$txt = "sid=".$sid."&uid=".$uid."&time=".$time."&cmflag=".$cmflag."&paetner=".UNIGIUM_PAETNER."&failback=".CHECK_FAIL_URL;
//$txt = "uid=".$uid."&time=".$time."&cmflag=".$cmflag."&paetner=".UNIGIUM_PAETNER."&failback=".CHECK_FAIL_URL;
//$txt = "uid=".$uid."&time=".$time."&cmflag=".$cmflag."&paetner=".UNIGIUM_PAETNER;
$auth = passport_encrypt($txt,UNIGIUM_KEY);
$sign = md5($auth.UNIGIUM_KEY);
$url = CHECK_URL."?auth=".rawurlencode($auth)."&sign=".$sign."&tage=".UNIGIUM_PAETNER;
$decrypt = passport_decrypt($auth,UNIGIUM_KEY);
echo "测试 传递参数 ".$txt."<br><hr>";
echo "密文 ".$auth."<br><hr>";
echo "length =>".strlen($auth)."<br><hr>";
echo "解码结果 ".$decrypt."<br><hr>";
?>
<?php
function passport_encrypt($txt, $key)
{
srand((double)microtime() * 1000000);
$encrypt_key = md5(rand(0, 32000));
$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(passport_key($tmp, $key));
}
function passport_decrypt($txt, $key)
{
$txt = passport_key(base64_decode($txt), $key);
$tmp = '';
for($i = 0;$i < strlen($txt); $i++)
{
$md5 = $txt[$i];
$tmp .= $txt[++$i] ^ $md5;
}
return $tmp;
}
function passport_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;
}
?>
PHP加密解密
最新推荐文章于 2024-09-28 17:54:20 发布