>  기사  >  백엔드 개발  >  求1解密函数的对应加密函数

求1解密函数的对应加密函数

WBOY
WBOY원래의
2016-06-13 12:53:18750검색

求一解密函数的对应加密函数

本帖最后由 xuzuning 于 2013-02-21 10:07:35 编辑 现在已知一解密函数(readkey)如下,求对应的加密函数
<br>
function authcode( $string, $operation = "DECODE", $key = "", $expiry = 0 )<br>
{<br>
				$ckey_length = 4;<br>
				$key = md5( $key != "" ? $key : "a2264dxLupVMlkqR" );<br>
				$keya = md5( substr( $key, 0, 16 ) );<br>
				$keyb = md5( substr( $key, 16, 16 ) );<br>
				$keyc = $ckey_length ? $operation == "DECODE" ? substr( $string, 0, $ckey_length ) : substr( md5( microtime( ) ), 0 - $ckey_length ) : "";<br>
				$cryptkey = $keya.md5( $keya.$keyc );<br>
				$key_length = strlen( $cryptkey );<br>
				$string = $operation == "DECODE" ? base64_decode( substr( $string, $ckey_length ) ) : sprintf( "%010d", $expiry ? $expiry + time( ) : 0 ).substr( md5( $string.$keyb ), 0, 16 ).$string;<br>
				$string_length = strlen( $string );<br>
				$result = "";<br>
				$box = range( 0, 255 );<br>
				$rndkey = array( );<br>
				$i = 0;<br>
				for ( ;	$i 
				{<br>
								$rndkey[$i] = ord( $cryptkey[$i % $key_length] );<br>
				}<br>
				$j = $i = 0;<br>
				for ( ;	$i 
				{<br>
								$j = ( $j + $box[$i] + $rndkey[$i] ) % 256;<br>
								$tmp = $box[$i];<br>
								$box[$i] = $box[$j];<br>
								$box[$j] = $tmp;<br>
				}<br>
				$a = $j = $i = 0;<br>
				for ( ;	$i 
				{<br>
								$a = ( $a + 1 ) % 256;<br>
								$j = ( $j + $box[$a] ) % 256;<br>
								$tmp = $box[$a];<br>
								$box[$a] = $box[$j];<br>
								$box[$j] = $tmp;<br>
								$result .= chr( ord( $string[$i] ) ^ $box[( $box[$a] + $box[$j] ) % 256] );<br>
				}<br>
				if ( $operation == "DECODE" )<br>
				{<br>
								if ( ( substr( $result, 0, 10 ) == 0 || 0 
								{<br>
												return substr( $result, 26 );<br>
								}<br>
								return "";<br>
				}<br>
				return $keyc.str_replace( "=", "", base64_encode( $result ) );<br>
}<br>
function readkey( $keys )<br>
{<br>
		$Leskey = authcode( $keys, "DECODE", "a2264dxLupVMlkqR" );<br>
		$Leskey = base64_decode( $Leskey );<br>
		$firstStr = substr( $Leskey, 0, 1 );<br>
		$Leskey = substr( $Leskey, 1 );<br>
		$Leskey = strrev( substr( $Leskey, 0, $firstStr ) ).chr( ord( substr( $Leskey, $firstStr, 1 ) ) ^ $firstStr ).strrev( substr( $Leskey, $firstStr + 1 ) ); <div class="clear">
                 
              
              
        
            </div>
성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.