实用的PHP带公钥加密类分享(每次加密结果都不一样哦)

WEB交互安全一直是个各大网站的首要解决方案,本文介绍的PHP加密类非常实用哦,带有公钥,这是最大的亮点,没有公钥是不能解密的,加密度非常高。

类代码:

public function encrypt($txt,$key=''){
if(empty($key)){
$key=$this->key;
}
srand((double)microtime()*1000000);
$encrypt_key = md5(rand(0,32000));
$ctr=0;
$tmp = '';
for ($i=0;$i<strlen($txt);$i++) {
if ($ctr==strlen($encrypt_key)){
$ctr=0;
}
$tmp.= substr($encrypt_key,1).(substr($txt,1));
$ctr++;
}
return $this->keyED($tmp,$key);
}

public function decrypt($txt,$key=''){
if(empty($key)){
$key=$this->key;
}

$txt = $this->keyED($txt,$key);
$tmp = '';
for ($i=0;$i<strlen($txt);$i++){
  $md5 = substr($txt,1);
  $i++;
  $tmp.= (substr($txt,1) ^ $md5);
}
return $tmp;

}

public function setKey($key){
if(empty($key)){
return null;
}
$this->key=$key;
}

public function getPK(){
return $this->key;
}

}

使用方法:

// 要加密的字符串
$string = '//www.jb51.cc';

// 实例化加密类
$jiami= new Jiami();

// 设置公钥
$jiami->setKey('qttc');

// 加密字符串
$enc = $jiami->encrypt($string,$jiami->getPK());

// 解密字符串
$dec = $jiami->decrypt($enc,$jiami->getPK());

echo '';
echo '加密前 : '.$string .'
';
echo '加密后 : '.$enc .'
';
echo '解密后 : '.$dec;
?>

页面执行结果

结果1:

结果2:

由以上结果可以看到,每次加密产生的加密字符串都不一样,这是随机的。 解密的时候,需要使用加密时的公钥,否则无法解密。如你这边加密公钥使用‘qttc',解密的时候,也需要使用这个'qttc'作为公钥去解密,否则无法解密。

相关文章

文章浏览阅读8.4k次,点赞8次,收藏7次。SourceCodester Onl...
文章浏览阅读3.4k次,点赞46次,收藏51次。本文为大家介绍在...
文章浏览阅读1.1k次。- php是最优秀, 最原生的模板语言, 替代...
文章浏览阅读1.1k次,点赞18次,收藏15次。整理K8s网络相关笔...
文章浏览阅读1.2k次,点赞22次,收藏19次。此网络模型提供了...
文章浏览阅读1.1k次,点赞14次,收藏19次。当我们谈论网络安...