코드 복사 코드는 다음과 같습니다.
function authcode($string, $Operation = 'DECODE', $key = '' , $expiry = 0) {
$ckey_length = 4; // 무작위 키 길이 범위는 0-32입니다.
// 원본 텍스트와 키가 동일하더라도 무작위 키를 추가하면 암호문이 불규칙해질 수 있습니다. 정확히 동일하더라도 암호화 결과도 매번 달라져 크래킹 난이도가 높아집니다.
// 값이 클수록 암호문 변경 패턴이 커집니다. 암호문 변경 = 16의 $ckey_length
// 이 값이 0이면 임의 키가 생성되지 않습니다.
$key = md5($key ? $key : UC_KEY);
$keya = md5(substr($key, 0, 16))
$keyb = md5(substr($key, 16, 16));
$keyc = $ckey_length ? ($operation == 'DECODE' ? substr($string, 0, $ckey_length): substr(md5(microtime()), -$ckey_length)) : ''; $cryptkey = $keya.md5($keya.$keyc);
$key_length = strlen($cryptkey);
$string = $operation == 'DECODE' ?substr($string, $ckey_length )) : sprintf(' 0d', $expiry ? $expiry time() : 0).substr(md5($string.$keyb), 0, 16).$string
$string_length = strlen($ string; );
$result = '';
$box = range(0, 255)
$rndkey = array()
for($i = 0; $i <= 255 ; $i ) {
$rndkey[$i] = ord($cryptkey[$i % $key_length])
}
for($j = $i = 0; $i < 256 ; $i ) {
$j = ($j $box[$i] $rndkey[$i])
$tmp = $box[$i]
$box[ $ i] = $box[$j];
$box[$j] = $tmp
}
for($a = $j = $i = 0; $i < $string_length ; $i ) {
$a = ($a 1) % 256;
$j = ($j $box[$a]) % 256;
$box[$a] = $box[$j];
$box[$j] = $tmp;
$result .= chr(ord($string[$i]) ^ ( $box[($box[$a] $box[$j]) % 256]))
}
if($Operation == 'DECODE') {
if((substr( $ 결과, 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 ''; return $keyc.str_replace('=', '', base64_encode($result))
}
}
/************************************************** *************************/
$string = authcode("Hello " ,"ENCODE","HTML_TCCJ_AUTH");
echo $string,'
'
echo authcode($string,"DECODE","HTML_TCCJ_AUTH"),'
위 내용은 센터 내용을 포함해 센터 UCenter의 가역적 암호화 기능의 인증코드 기능 코드를 소개한 내용이 PHP 튜토리얼에 관심이 있는 친구들에게 도움이 되었으면 좋겠습니다.