成人精品一区二区三区中文字幕-成人精品一区二区三区-成人精品一级毛片-成人精品亚洲-日本在线视频一区二区-日本在线视频免费

導航首頁 ? 技術教程 ? PHP對稱加密函數實現數據的加密解密
全站頭部文字 我要出現在這里
PHP對稱加密函數實現數據的加密解密 663 2024-01-23   

項目中有一個地方用到了將用戶ID加密、傳至下個接點進行反解的需求。(原諒我不能透漏太多-_-!),第一個想到的就是康盛Ucenter中的一個函數,后來搜了下,在簡明魔法中也找到了個簡單的方法,遂整合了下,形成了自己使用的函數。

一、對稱加密

發送方將明文使用密鑰和算法處理成密文發送出去,接收方使用密鑰和算法將密文處理成明文,發收信雙方使用同一個密鑰對數據進行加密和解密。

查看圖片

因為使用同一個密鑰加密、解密,所以安全性上不僅與算法有關,密鑰的安全也很重要。

當然并不是密鑰越復雜越好,相反密鑰通常比較小的,因為雖然密鑰越大,加密越強,但加密與解密的過程越慢,所以密鑰的大小既要照顧到安全性,也要照顧到效率。

畢竟對稱加密算法的特點是算法公開、計算量小、加密速度快、加密效率高,沒了效率高這一優勢,還不如直接用非對稱加密。

此外,每對用戶每次使用對稱加密算法時,都需要使用其他人不知道的惟一鑰匙,這會使得發收信雙方所擁有的鑰匙數量呈幾何級數增長,密鑰管理成為用戶的負擔。

對稱加密算法在分布式網絡系統上使用較為困難,主要是因為密鑰管理困難,使用成本較高。

二、非對稱加密

非對稱加密相對來說,就安全很多了,它使用了一對密鑰,公開密鑰和私有密鑰,分別用來進行加密和解密。私鑰只能由一方安全保管,不能外泄,而公鑰則可以發給任何請求它的人。

查看圖片

最常見的非對稱加密,應該就是銀行系統,支付平臺了。比如我們申請支付寶或者銀聯支付的接口時,會得到一個公鑰,商城中進行支付是,用公鑰將信息加密提交給平臺,平臺使用密鑰對你的信息解密,進行支付操作等。

雖然非對稱加密很安全,但是和對稱加密比起來,它非常的慢,所以我們一般處理的話,大部分是用對稱加密來傳送消息,但對稱加密所使用的密鑰我們可以通過非對稱加密的方式發送出去,回想一下你申請到的支付接口,是不是給了你一對密鑰呢?^.^

三、結合使用

對稱性加密速度快,發送大量數據時用比較好。非對稱加密加密和解密花費時間長、速度慢,只適合對少量數據進行加密,但是,非對稱加密的安全性是極高的。

揚長避短:將對稱加密的密鑰使用非對稱加密的公鑰進行加密,然后發送出去,接收方使用私鑰進行解密得到對稱加密的密鑰,然后雙方可以使用對稱加密來進行溝通。

查看圖片

項目中使用的方法不宜透露,只在這里列出兩個其他的例子吧。第一個是ucenter中的,第二個是簡明魔法中看到的。

需要注意的是,由于是base64算法,加密后的字符串有可能會出現 + ,如果是用在url中,是不友好的,可以在外部或改下方法,正則驗證遞歸調取下。

/**
 * 字符串加密以及解密函數
 * @param string $string 原文或者密文
 * @param string $operation 操作(ENCODE | DECODE), 默認為 DECODE
 * @param string $key 密鑰
 * @param int $expiry 密文有效期, 加密時候有效, 單位 秒,0 為永久有效
 * @return string 處理后的 原文或者 經過 base64_encode 處理后的密文
 */
function _authcode ($string, $operation = 'DECODE', $key = 'Ruesin', $expiry = 0)
{
 $ckey_length = 4;
 
 $key = md5($key);
 $keya = md5(substr($key, 0, 16));
 $keyb = md5(substr($key, 16, 16));
 $keyc = $ckey_length ? ($operation == 'DECODE' ? substr($string, 0, 
   $ckey_length) : substr(md5(microtime()), - $ckey_length)) : '';
 
 $cryptkey = $keya . md5($keya . $keyc);
 $key_length = strlen($cryptkey);
 
 $string = $operation == 'DECODE' ? base64_decode(
   substr($string, $ckey_length)) : sprintf('%010d', 
   $expiry ? $expiry + time() : 0) . substr(md5($string . $keyb), 0, 16) .
    $string;
 $string_length = strlen($string);
 
 $result = '';
 $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 == 'DECODE') {
  if ((substr($result, 0, 10) == 0 || substr($result, 0, 10) - time() > 0) &&
     substr($result, 10, 16) ==
     substr(md5(substr($result, 26) . $keyb), 0, 16)) {
   return substr($result, 26);
  } else {
   return '';
  }
 } else {
  return $keyc . str_replace('=', '', base64_encode($result));
 }
}
/*********************************************************************
函數名稱:encrypt
函數作用:加密解密字符串
使用方法:
加密  :encrypt('str','E','nowamagic');
解密  :encrypt('被加密過的字符串','D','nowamagic');
參數說明:
$string :需要加密解密的字符串
$operation:判斷是加密還是解密:E:加密 D:解密
$key  :加密的鑰匙(密匙);
*********************************************************************/
function encrypt($string,$operation,$key='')
{
 $key=md5($key);
 $key_length=strlen($key);
 $string=$operation=='D'?base64_decode($string):substr(md5($string.$key),0,8).$string;
 $string_length=strlen($string);
 $rndkey=$box=array();
 $result='';
 for($i=0;$i<=255;$i++)
 {
  $rndkey[$i]=ord($key[$i%$key_length]);
  $box[$i]=$i;
 }
 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=='D')
 {
  if(substr($result,0,8)==substr(md5(substr($result,8).$key),0,8))
  {
   return substr($result,8);
  }
  else
  {
   return'';
  }
 }
 else
 {
  return str_replace('=','',base64_encode($result));
 }
}

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持綠夏網。



主站蜘蛛池模板: 黄视频免费看网站| 电影院电影| 河南省gdp城市排名| 女孩们电影| 1988年英国的白蛇传说| 周末父母42集剧情介绍| 试看60秒做受小视频| 神雕侠侣电影| 国测四年级语文试题| 吴彦祖激情戏| 阿星| 活动评价| 影片 - theav| 爱在一起麻辣烫| 大连好生活| 平安建设工作会议记录| 女同激情视频| 扎西顿珠的个人资料简介 | 《推拿》完整版播放| 扭曲的欲望| 孽子 电影| 秀人网周妍希| 我是特种兵剧情介绍| 《爱你》演员表| 胎儿双顶径标准对照表| 都市女孩| 工会基层组织选举工作条例| 风筝 电影| 韩国电影《我是谁》演员表介绍| 金枝欲孽在线观看免费完整版| 程嘉美电影| 伊人1314| 绫濑天| 在线播放免费观看| 卢靖姗个人资料| cctv16节目表今天目表| 豪勇七蛟龙 电影| 斓曦个人简介| 墓王之王动漫完整版在线观看| 帕瓦德奥特曼| 乔治克鲁尼个人资料|

!!!站長長期在線接!!!

網站、小程序:定制開發/二次開發/仿制開發等

各種疑難雜癥解決/定制接口/定制采集等

站長微信:lxwl520520

站長QQ:1737366103