首頁 >後端開發 >php教程 >php中對稱加密演算法的實現

php中對稱加密演算法的實現

墨辰丷
墨辰丷原創
2018-05-26 16:42:382018瀏覽

最近突發奇想要在資料庫裡保存一些機密的東西,然後就想著怎麼讓別人即使進入到了資料庫也看不懂儲存的是什麼,那麼只有加密了;可是我們自己還要看呢,那就只能找一些對稱加密的演算法了,我們想看的時候再解密回來。以下就介紹了php中簡單的對稱加密演算法實作。

前言

在網路上找到了一個不錯的PHP方面的對稱加密演算法;在PHP的語法環境裡,有urlencode與urldecode ,base64_encode和base64_decode自帶的對稱演算法,不過這些自帶的演算法不能稱之為加密演算法,只能說是編碼方式而已。可是我們可以利用這些來進行一些加工,來實現簡單的加密和解密演算法。

這次的加密和解密演算法是使用base64的方式改編的。通常我們使用base64_encode($str)產生的字串,不經過任何的加工的話,base64_decode()就能轉回我們之前的字串;可是如果我們在base64_encode()之後的字串裡插入幾個字元呢,那他就轉不回來了,即使轉過來也不是我們自己的字串。

範例程式碼如下:

#
 <?php
 $content = "大家好,我是中国人,你是谁";

 /**
 * 简单对称加密算法之加密
 * @param String $string 需要加密的字串
 * @param String $skey 加密EKY
 * @return String
 */
 function encode($string = &#39;&#39;, $skey = &#39;wenzi&#39;) {
 $strArr = str_split(base64_encode($string));
 $strCount = count($strArr);
 foreach (str_split($skey) as $key => $value)
  $key < $strCount && $strArr[$key].=$value;
 return str_replace(array(&#39;=&#39;, &#39;+&#39;, &#39;/&#39;), array(&#39;O0O0O&#39;, &#39;o000o&#39;, &#39;oo00o&#39;), join(&#39;&#39;, $strArr));
 }

 /**
 * 简单对称加密算法之解密
 * @param String $string 需要解密的字串
 * @param String $skey 解密KEY
 * @return String
 */
 function decode($string = &#39;&#39;, $skey = &#39;wenzi&#39;) {
 $strArr = str_split(str_replace(array(&#39;O0O0O&#39;, &#39;o000o&#39;, &#39;oo00o&#39;), array(&#39;=&#39;, &#39;+&#39;, &#39;/&#39;), $string), 2);
 $strCount = count($strArr);
 foreach (str_split($skey) as $key => $value)
  $key <= $strCount && $strArr[$key][1] === $value && $strArr[$key] = $strArr[$key][0];
 return base64_decode(join(&#39;&#39;, $strArr));
 }

 echo &#39;<pre class="brush:php;toolbar:false">&#39;;
 echo "string : " . $content . " <br />";
 echo "encode : " . ($enstring = encode($content)) . &#39;<br />&#39;;
 echo "decode : " . decode($enstring);

 exit();

上面的演算法裡我們可以看到:我們把base64_encode()產生的字元中插入我們提前設定的密鑰,然後再把裡面的特殊字元替換,即使別人看到這樣的字串也不知道是什麼。當然,這裡我們再稍微的改進下,例如把金鑰倒著插入到字串裡,密鑰base64後再進行插入等等,插入金鑰後再base64一次。

當然解密就是加密的反方向了,思考了一會兒才知道解密的原理:之前我們在字串裡插入了一些字符,現在解密時我們就要把他摘出來,首先把加密後的字串按每個陣列裡2個元素進行分組,然後判斷第二個字元是不是密鑰裡的,如果是,那麼第一個字元就是原來base64裡的字元。

以上就是本文的全部內容,希望對大家的學習有所幫助。


相關推薦:

PHP使用遞歸演算法無限遍歷陣列的方法

PHP常用排序演算法實例詳解

#PHP常用演算法與資料結構實例詳解

#

以上是php中對稱加密演算法的實現的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn