>백엔드 개발 >PHP 튜토리얼 >PHP 가역 암호화 방법 및 원리

PHP 가역 암호화 방법 및 원리

墨辰丷
墨辰丷원래의
2018-06-07 16:11:112594검색

이 글은 주로 PHP 가역 암호화의 방법과 원리를 소개합니다. 관심 있는 친구들이 참고하면 좋습니다.

PHP 코드는 다음과 같습니다.

<?php
class encryptCalss
{
var $key=12;
function encode($txt){
for($i=0;$i<strlen($txt);$i++){
$txt[$i]=chr(ord($txt[$i])+$this->key);
}
return $txt=urlencode(base64_encode(urlencode($txt)));
}
function decode($txt){
$txt=urldecode(base64_decode($txt));
for($i=0;$i<strlen($txt);$i++){
$txt[$i]=chr(ord($txt[$i])-$this->key);
}
return $txt;
}
}
?>

discuz 암호화 및 복호화:

<?php
/**
 * 
 * @param string $string 原文或者密文
 * @param string $operation 操作(ENCODE | DECODE), 默认为 DECODE
 * @param string $key 密钥
 * @param int $expiry 密文有效期, 加密时候有效, 单位 秒,0 为永久有效
 * @return string 处理后的 原文或者 经过 base64_encode 处理后的密文
 * @example 
 *  $a = authcode(&#39;abc&#39;, &#39;ENCODE&#39;, &#39;key&#39;);
 *  $b = authcode($a, &#39;DECODE&#39;, &#39;key&#39;); // $b(abc)
 * 
 *  $a = authcode(&#39;abc&#39;, &#39;ENCODE&#39;, &#39;key&#39;, 3600);
 *  $b = authcode(&#39;abc&#39;, &#39;DECODE&#39;, &#39;key&#39;); // 在一个小时内,$b(abc),否则 $b 为空
 */
function authcode($string,$operation=&#39;DECODE&#39;,$key=&#39;&#39;,$expiry=0){
  $ckey_length=4;
  $key=md5($key ? $key:"kalvin.cn");
  $keya=md5(substr($key,0,16));
  $keyb=md5(substr($key,16,16));
  $keyc=$ckey_length ? ($operation==&#39;DECODE&#39; ? substr($string,0,$ckey_length):substr(md5(microtime()),-$ckey_length)):&#39;&#39;;
  $cryptkey=$keya.md5($keya.$keyc);
  $key_length=strlen($cryptkey);
  $string=$operation==&#39;DECODE&#39; ? base64_decode(substr($string,$ckey_length)):sprintf(&#39;%010d&#39;,$expiry ? $expiry+time():0).substr(md5($string.$keyb),0,16).$string;
  $string_length=strlen($string);
  $result=&#39;&#39;;
  $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])%256;
    $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;
    $tmp=$box[$a];
    $box[$a]=$box[$j];
    $box[$j]=$tmp;
    $result.=chr(ord($string[$i]) ^ ($box[($box[$a]+$box[$j])%256]));
  }
  if($operation==&#39;DECODE&#39;){
    if((substr($result,0,10)==0||substr($result,0,10)-time()>0)&&substr($result,10,16)==substr(md5(substr($result,26).$keyb),0,16)){
      returnsubstr($result,26);
    }else{
      return&#39;&#39;;
    }
  }else{
    return $keyc.str_replace(&#39;=&#39;,&#39;&#39;,base64_encode($result));
  }
}
?>

요약: 위 내용은 이 글의 전체 내용입니다. 모든 분들의 학습에 도움이 되기를 바랍니다.

관련 권장사항:

PHP에서 페이지 정적화를 달성하는 여러 방법에 대한 자세한 설명

C#과 일치하는 DES 암호화 및 암호 해독을 구현하는 PHP 방법 PHP 실용성 튜토리얼, 확인, 이스케이프 및 비밀번호 방법

위 내용은 PHP 가역 암호화 방법 및 원리의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.