> 백엔드 개발 > PHP 튜토리얼 > 还是解码有关问题,依旧有点有关问题

还是解码有关问题,依旧有点有关问题

WBOY
풀어 주다: 2016-06-13 10:12:48
원래의
853명이 탐색했습니다.

还是解码问题,,依旧有点问题

PHP code
<!--Code highlighting produced by Actipro CodeHighlighter (freeware)http://www.CodeHighlighter.com/--><?phpfunction encryptCookie($value){   if(!$value){return false;}   $key = 'paxospass1234!';   $text = $value;   $iv_size = mcrypt_get_iv_size(MCRYPT_RIJNDAEL_256, MCRYPT_MODE_CBC);   $iv = mcrypt_create_iv($iv_size, MCRYPT_RAND);   $crypttext = mcrypt_encrypt(MCRYPT_RIJNDAEL_256, $key, $text, MCRYPT_MODE_CBC, $iv);   return array(trim(base64_encode($crypttext)),$iv); //encode for cookie}function decryptCookie($value,$iv){       if(!$value){return false;}   $value = base64_decode($value);   $key = 'paxospass1234!';   $text = $value;  // $iv_size = mcrypt_get_iv_size(MCRYPT_RIJNDAEL_256, MCRYPT_MODE_CBC);  // $iv = mcrypt_create_iv($iv_size, MCRYPT_RAND);   $decrypttext = mcrypt_decrypt(MCRYPT_RIJNDAEL_256, $key, $text, MCRYPT_MODE_CBC, $iv);   return $decrypttext;}$str="this is for encry";$s=encryptCookie($str);echo decryptCookie($s[0],$s[1]);?>
로그인 후 복사


没错。这函数正确,但是问题是,我要发到邮件里的是加密的代码,但是解码要到另一个网页,

问题是这个iv 打印出来时很多的方框框乱码,,怎么处理,,或者怎么让iv固定,我直接写$iv='123' 还报警告

------解决方案--------------------
呵呵,你咋直接用了那个函数了,我只是提供下简单示例。
实际生产环境肯定是加密是一端,解密是另一端的。
所以你是问另一端怎么得到那个随机不定iv吧?
因为CBC的iv固定是32字节的,所以直接把它拼进加密串就行了
PHP code
<?phpfunction encryptCookie($value){   if(!$value){return false;}   $key = 'paxospass1234!';   $text = $value;   $iv_size = mcrypt_get_iv_size(MCRYPT_RIJNDAEL_256, MCRYPT_MODE_CBC);   $iv      = mcrypt_create_iv($iv_size, MCRYPT_RAND);   $crypttext = mcrypt_encrypt(MCRYPT_RIJNDAEL_256,$key,$text, MCRYPT_MODE_CBC, $iv);   $ivencode  = mcrypt_encrypt(MCRYPT_RIJNDAEL_256,$crypttext,$iv,MCRYPT_MODE_ECB);//其实直接拼接就可以,这里再做一次加密   return base64_encode($crypttext.$ivencode); //encode for cookie,iv拼接到串尾}function decryptCookie($value){   if(!$value){return false;}   $value   = base64_decode($value);   $rvalue  = substr($value,0,-32);//原加密串   $iv      = substr($value,-32);//iv   $iv      = mcrypt_decrypt(MCRYPT_RIJNDAEL_256,$rvalue,$iv,MCRYPT_MODE_ECB);//解密iv   $key = 'paxospass1234!';   $text = $rvalue;  // $iv_size = mcrypt_get_iv_size(MCRYPT_RIJNDAEL_256, MCRYPT_MODE_CBC);  // $iv = mcrypt_create_iv($iv_size, MCRYPT_RAND);   $decrypttext = mcrypt_decrypt(MCRYPT_RIJNDAEL_256, $key, $text, MCRYPT_MODE_CBC, $iv);                                                      return $decrypttext;}$str="this is for encry";$s=encryptCookie($str);echo "encrypt:".$s."<br/>";echo "decrypt:".decryptCookie($s);?><div class="clear">
                 
              
              
        
            </div>
로그인 후 복사
관련 라벨:
원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿