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

