PHP实现的DES加密解密类定义与用法示例
本文实例讲述了PHP实现的DES加密解密类定义与用法。分享给大家供大家参考,具体如下:
今天写App接口的时候需要传递加密数据给APP端,于是就写了下面的DES加密类,亲测正确代码如下
classCryptDes{ function__construct(){ $this->key='codelovers';//密钥 $this->iv='15548632';//偏移量 } /* *加密 */ functionencrypt($input){ $size=mcrypt_get_block_size(MCRYPT_DES,MCRYPT_MODE_CBC);//3DES加密将MCRYPT_DES改为MCRYPT_3DES $input=$this->pkcs5_pad($input,$size);//如果采用PaddingPKCS7,请更换成PaddingPKCS7方法。 $key=str_pad($this->key,8,'0');//3DES加密将8改为24 $td=mcrypt_module_open(MCRYPT_DES,'',MCRYPT_MODE_CBC,''); if($this->iv=='') { $iv=@mcrypt_create_iv(mcrypt_enc_get_iv_size($td),MCRYPT_RAND); } else { $iv=$this->iv; } @mcrypt_generic_init($td,$key,$iv); $data=mcrypt_generic($td,$input); mcrypt_generic_deinit($td); mcrypt_module_close($td); $data=base64_encode($data);//如需转换二进制可改成bin2hex转换 return$data; } /* *解密 */ functiondecrypt($encrypted){ $encrypted=base64_decode($encrypted);//如需转换二进制可改成bin2hex转换 $key=str_pad($this->key,8,'0');//3DES加密将8改为24 $td=mcrypt_module_open(MCRYPT_DES,'',MCRYPT_MODE_CBC,'');//3DES加密将MCRYPT_DES改为MCRYPT_3DES if($this->iv=='') { $iv=@mcrypt_create_iv(mcrypt_enc_get_iv_size($td),MCRYPT_RAND); } else { $iv=$this->iv; } $ks=mcrypt_enc_get_key_size($td); @mcrypt_generic_init($td,$key,$iv); $decrypted=mdecrypt_generic($td,$encrypted); mcrypt_generic_deinit($td); mcrypt_module_close($td); $y=$this->pkcs5_unpad($decrypted); return$y; } functionpkcs5_pad($text,$blocksize){ $pad=$blocksize-(strlen($text)%$blocksize); return$text.str_repeat(chr($pad),$pad); } functionpkcs5_unpad($text){ $pad=ord($text{strlen($text)-1}); if($pad>strlen($text)){ returnfalse; } if(strspn($text,chr($pad),strlen($text)-$pad)!=$pad){ returnfalse; } returnsubstr($text,0,-1*$pad); } functionPaddingPKCS7($data){ $block_size=mcrypt_get_block_size(MCRYPT_DES,MCRYPT_MODE_CBC);//3DES加密将MCRYPT_DES改为MCRYPT_3DES $padding_char=$block_size-(strlen($data)%$block_size); $data.=str_repeat(chr($padding_char),$padding_char); return$data; } }
用法如下:
$str='www.nhooo.com'; $des=newCryptDes(); $mres=$des->encrypt($str);//加密 echo$mres."
"; $jres=$des->decrypt($mres);//解密 echo$jres."
";
运行结果:
TxqbmhK86YWdTtTAQoDOqA==
www.nhooo.com
附录:php7des加密解密
以下内容转自:https://blog.csdn.net/qq_35979073/article/details/81449590
1.在linux环境中如果没有装encrypt扩展或者php版本大于7.1不支持encrypt加密扩展
可以使用openssl加密扩展
下面是封装的加密和解密的方法可直接调用
/** *des-ecb加密 *@paramstring$data要被加密的数据 *@paramstring$key加密密钥(64位的字符串) */ functiondes_ecb_encrypt($data,$key){ returnopenssl_encrypt($data,'des-ecb',$key); } /** *des-ecb解密 *@paramstring$data加密数据 *@paramstring$key加密密钥 */ functiondes_ecb_decrypt($data,$key){ returnopenssl_decrypt($data,'des-ecb',$key); }
说明:$key加密密钥(64位的字符串) 自己定义的
PS:关于加密解密感兴趣的朋友还可以参考本站在线工具:
在线DES加密/解密工具
http://tools.jb51.net/password/des_encode
MD5在线加密工具:
http://tools.jb51.net/password/CreateMD5Password
在线散列/哈希算法加密工具:
http://tools.jb51.net/password/hash_encrypt
在线MD5/hash/SHA-1/SHA-2/SHA-256/SHA-512/SHA-3/RIPEMD-160加密工具:
http://tools.jb51.net/password/hash_md5_sha
在线sha1/sha224/sha256/sha384/sha512加密工具:
http://tools.jb51.net/password/sha_encode
更多关于PHP相关内容感兴趣的读者可查看本站专题:《php加密方法总结》、《PHP编码与转码操作技巧汇总》、《PHP数学运算技巧总结》、《PHP数组(Array)操作技巧大全》、《php字符串(string)用法总结》、《PHP数据结构与算法教程》、《php程序设计算法总结》及《php正则表达式用法总结》
希望本文所述对大家PHP程序设计有所帮助。
声明:本文内容来源于网络,版权归原作者所有,内容由互联网用户自发贡献自行上传,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任。如果您发现有涉嫌版权的内容,欢迎发送邮件至:czq8825#qq.com(发邮件时,请将#更换为@)进行举报,并提供相关证据,一经查实,本站将立刻删除涉嫌侵权内容。