authcode.php 0 验证数据有效性 // substr($result, 10, 16) == substr(md5(substr($result, 26).$keyb), 0, 16) 验证数据完整性 // 验证数据有效性,请看未加密明文的格式 if ((substr($result, 0, 10) == 0 || substr($res
          
  0 验证数据有效性
        // substr($result, 10, 16) == substr(md5(substr($result, 26).$keyb), 0, 16) 验证数据完整性
        // 验证数据有效性,请看未加密明文的格式  
        if ((substr($result, 0, 10) == 0 || substr($result, 0, 10) - time() > 0) && substr($result, 10, 16) == substr(md5(substr($result, 26).$keyb), 0, 16)) {  
            return substr($result, 26);
        }
        else {
            return '';
        }
    }
    else {
        // 把动态密匙保存在密文里,这也是为什么同样的明文,生产不同密文后能解密的原因
        // 因为加密后的密文可能是一些特殊字符,复制过程可能会丢失,所以用base64编码
        $ustr = $keyc.str_replace('=', '', base64_encode($result));
        //函数代码可能会生成+、/这样的字符,导致通过URL传值取回时被转义,导致无法解密。
        $ustr = str_replace('+', '-', $ustr);
        $ustr = str_replace('/', '_', $ustr);
        //稍加修改,把这几个字符替换成其它字符,解密时再替换回去,这样就完美了!
        return $ustr;
    }
}
//参数解释
//$string:明文 或 密文
//$operation:DECODE表示解密,其它表示加密
//$key:密匙
//$expiry:密文有效期
$aa = '!@#$%^&*()_+1234567890qwertyuiop';
echo '明文:'. $aa .''; 
$bb = authcode($aa, $operation='ENCODE', $key='ewt235hgf2464ngh42c34', $expiry=5);
echo '密文:'. $bb .'';
$cc = authcode($bb, $operation='DECODE', $key='ewt235hgf2464ngh42c34', $expiry=5);
echo '解密后:'. $cc .'';
sleep(7);
echo '7秒后解密:'. authcode($bb, $operation='DECODE', $key='ewt235hgf2464ngh42c34', $expiry=7);
        
        