Heim  >  Artikel  >  php教程  >  edauth高效可逆随机加密函数

edauth高效可逆随机加密函数

WBOY
WBOYOriginal
2016-06-07 11:42:151011Durchsuche

edauth高效可逆随机加密函数,性能比Discuz的authcode函数更优化,响应更快
在项目配置文件中定议 'AUTH_KEY'=>'你的密匙字符串'// edauth高效可逆随机加密函数参数解释 <br> // author: PGCao(排骨曹) <br> #------------------------------------------------------------------------#<br> # $string: 明文 或 密文<br> # $operation:true表示加密,false表示解密<br> # $key: 密匙<br> # $outtime:密文有效期, 单位为秒<br> # $entype:加密方式 有md5和sha1两种 加密解密需要统一使用同一种方式才能正确还原明文<br> function edauth($string, $operation = true, $key = '', $outtime = 0, $entype = 'md5'){<br>     $key_length = 4;<br>     if($entype == 'md5'){ //使用md5方式<br>       $long_len = 32; $half_len = 16; $entype == 'md5';<br>     }else{ //使用sha1方式<br>       $long_len = 40; $half_len = 20; $entype == 'sha1';<br>     }<br>     $key = $key != '' ? $key : substr(md5($_SERVER['DOCUMENT_ROOT'].C('AUTH_KEY').$_SERVER['REMOTE_ADDR']),0,30);<br>     $fixedKey = hash($entype, $key); <br>     $egiskeys = md5(substr($fixedKey, $half_len, $half_len)); <br>     $runtoKey = $key_length ? ($operation ? substr(hash($entype, microtime(true)), -$key_length) : substr($string, 0, $key_length)) : ''; <br>     $keys = hash($entype, substr($runtoKey, 0, $half_len) . substr($fixedKey, 0, $half_len) . substr($runtoKey, $half_len) . substr($fixedKey, $half_len));<br>     $string = $operation ? sprintf('%010d', $outtime ? $outtime + time() : 0).substr(md5($string.$egiskeys), 0, $half_len) . $string : base64_decode(substr($string, $key_length)); <br>     $i = 0; $result = ''; <br>     $string_length = strlen($string);<br>     for ($i = 0; $i          $result .= chr(ord($string{$i}) ^ ord($keys{$i % $long_len})); <br>     }<br>     if($operation){<br>       return $runtoKey . str_replace('=', '', base64_encode($result));<br>     }else{<br>         if((substr($result, 0, 10) == 0 || substr($result, 0, 10) - time() > 0) && substr($result, 10, $half_len) == substr(md5(substr($result, $half_len+10).$egiskeys), 0, $half_len)) {<br>             return substr($result, $half_len+10);<br>         } else {<br>             return '';<br>         }<br>     }<br> }以下是测速代码,有兴趣的PR可以试用authcode函数进行比较,同一页面用得越多越能体现出前后性能区别<?php <br /> //测试处理速度<br> echo "<h3>edauth函数</h3>";<br> $_runtime_ = microtime(true);<br> $str = "生产不同密文后能解密!^_^ ";<br> //for($i=0;$i //$str .= "OK";<br> $key = "12***89";<br> echo "<b>明文:</b>".$str."<hr>";<br> echo "<b>密文:</b>".$out = edauth($str, true, $key);<br> echo "<hr> <b>原文:</b>".edauth($out, false, $key);<br> echo "<hr> <b>明文:</b>".$str."<hr>";<br> echo "<b>密文:</b>".$out = edauth($str, true, $key);<br> echo "<hr> <b>原文:</b>".edauth($out, false, $key);<br> $runtime = number_format((microtime(true) - $_runtime_), 6);<br> echo '<hr>Runtime '. $runtime .' second(s)';<br> ?>

AD:真正免费,域名+虚机+企业邮箱=0元

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn