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(发邮件时,请将#更换为@)进行举报,并提供相关证据,一经查实,本站将立刻删除涉嫌侵权内容。