php 實(shí)現(xiàn)一個(gè)字符串加密解密的函數(shù)實(shí)例代碼
php 實(shí)現(xiàn)一個(gè)字符串加密解密的函數(shù)
函數(shù)代碼如下:
/********************************************************************* 函數(shù)名稱:encrypt 函數(shù)作用:加密解密字符串 使用方法: 加密 :encrypt('str','E','nowamagic'); 解密 :encrypt('被加密過的字符串','D','nowamagic'); 參數(shù)說明: $string :需要加密解密的字符串 $operation:判斷是加密還是解密:E:加密 D:解密 $key :加密的鑰匙(密匙); http://www.cnblogs.com/roucheng/ *********************************************************************/ 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)); } }
使用實(shí)例:
$id = 132; $token = encrypt($id, 'E', 'a'); echo '加密:'.encrypt($id, 'E', 'a'); echo '<br />'; echo '解密:'.encrypt($token, 'D', 'a');
運(yùn)行結(jié)果:
加密:AYCnIibFlg3ViRs
解密:132
感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!
- php數(shù)組函數(shù)序列之a(chǎn)rray_pop() - 刪除數(shù)組中的最后一個(gè)元素
- php array_pop()數(shù)組函數(shù)將數(shù)組最后一個(gè)單元彈出(出棧)
- PHP遞歸獲取目錄內(nèi)所有文件的實(shí)現(xiàn)方法
- PHP之十六個(gè)魔術(shù)方法詳細(xì)介紹
- PHP用戶驗(yàn)證和標(biāo)簽推薦的簡單使用
- PHP實(shí)現(xiàn)小偷程序?qū)嵗?/a>
- 利用php做服務(wù)器和web前端的界面進(jìn)行交互
- php將服務(wù)端的文件讀出來顯示在web頁面實(shí)例
- PHP仿微信發(fā)紅包領(lǐng)紅包效果
- PHPCMS忘記后臺密碼的解決辦法
- php array_pop 刪除數(shù)組最后一個(gè)元素實(shí)例
相關(guān)文章
PHP中SSO Cookie登錄分析和實(shí)現(xiàn)
單點(diǎn)登錄SSO(Single Sign-On)是身份管理中的一部分。SSO的一種較為通俗的定義是:SSO是指訪問同一服務(wù)器不同應(yīng)用中的受保護(hù)資源的同一用戶,只需要登錄一次,即通過一個(gè)應(yīng)用中的安全驗(yàn)證后,再訪問其他應(yīng)用中的受保護(hù)資源時(shí),不再需要重新登錄驗(yàn)證2015-11-11YII Framework學(xué)習(xí)之request與response用法(基于CHttpRequest響應(yīng))
這篇文章主要介紹了YII Framework學(xué)習(xí)之request與response用法,詳細(xì)介紹了CHttpRequest響應(yīng)request與response的使用技巧,需要的朋友可以參考下2016-03-03AJAX PHP無刷新form表單提交的簡單實(shí)現(xiàn)(推薦)
下面小編就為大家?guī)硪黄狝JAX PHP無刷新form表單提交的簡單實(shí)現(xiàn)(推薦)。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2016-09-09thinkphp中session和cookie無效的解決方法
這篇文章主要介紹了thinkphp中session和cookie無效的解決方法,涉及針對BOM頭的分析與刪除方法,具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2014-12-12php array_pop 刪除數(shù)組最后一個(gè)元素實(shí)例
這篇文章主要介紹了php array_pop 刪除數(shù)組最后一個(gè)元素實(shí)例的相關(guān)資料,需要的朋友可以參考下2016-11-11thinkphp中html:list標(biāo)簽傳遞多個(gè)參數(shù)實(shí)例
這篇文章主要介紹了thinkphp中html:list標(biāo)簽傳遞多個(gè)參數(shù)的解決方法,在處理參數(shù)傳遞的情況非常具有實(shí)用價(jià)值,需要的朋友可以參考下2014-10-10Yii2 隊(duì)列 shmilyzxt/yii2-queue 簡單概述
這篇文章主要介紹了Yii2 隊(duì)列 shmilyzxt/yii2-queue 的簡單概述,需要的朋友可以參考下2017-08-08