Thinkphp 常用加解密方式

1. 簡(jiǎn)易型

function encryptDecrypt($key, $string, $decrypt){  
    if($decrypt){  
        $decrypted = rtrim(mcrypt_decrypt(MCRYPT_RIJNDAEL_256, md5($key), base64_decode($string), MCRYPT_MODE_CBC, md5(md5($key))), "12");  
        return $decrypted;  
    }else{  
        $encrypted = base64_encode(mcrypt_encrypt(MCRYPT_RIJNDAEL_256, md5($key), $string, MCRYPT_MODE_CBC, md5(md5($key))));  
        return $encrypted;  
    }  
}  
 
//加密:"z0JAx4qMwcF+db5TNbp/xwdUM84snRsXvvpXuaCa4Bk=" 
echo encryptDecrypt('password', 'Hello',0);  
//解密:"Helloweba歡迎您" 
echo encryptDecrypt('password', 'xxxxxx',1); 

2. 普通型

//加密函數(shù) 
function lock_url($txt,$key='liiu'){ 
    $chars = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-=+"; 
    $nh = rand(0,64); 
    $ch = $chars[$nh]; 
    $mdKey = md5($key.$ch); 
    $mdKey = substr($mdKey,$nh%8, $nh%8+7); 
    $txt = base64_encode($txt); 
    $tmp = ''; 
    $i=0;$j=0;$k = 0; 
    for ($i=0; $i<strlen($txt); $i++) { 
        $k = $k == strlen($mdKey) ? 0 : $k; 
        $j = ($nh+strpos($chars,$txt[$i])+ord($mdKey[$k++]))%64; 
        $tmp .= $chars[$j]; 
    } 
    return urlencode($ch.$tmp); 
} 
//解密函數(shù) 
function unlock_url($txt,$key='liiu'){ 
    $txt = urldecode($txt); 
    $chars = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-=+"; 
    $ch = $txt[0]; 
    $nh = strpos($chars,$ch); 
    $mdKey = md5($key.$ch); 
    $mdKey = substr($mdKey,$nh%8, $nh%8+7); 
    $txt = substr($txt,1); 
    $tmp = ''; 
    $i=0;$j=0; $k = 0; 
    for ($i=0; $i<strlen($txt); $i++) { 
        $k = $k == strlen($mdKey) ? 0 : $k; 
        $j = strpos($chars,$txt[$i])-$nh - ord($mdKey[$k++]); 
        while ($j<0) $j+=64; 
        $tmp .= $chars[$j]; 
    } 
    return base64_decode($tmp); 
} 

3. 普通改良型

//改進(jìn)后的算法 
//加密函數(shù) 
function lock_url($txt,$key='str'){ 
    $txt = $txt.$key; 
    $chars = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-=+"; 
    $nh = rand(0,64); 
    $ch = $chars[$nh]; 
    $mdKey = md5($key.$ch); 
    $mdKey = substr($mdKey,$nh%8, $nh%8+7); 
    $txt = base64_encode($txt); 
    $tmp = ''; 
    $i=0;$j=0;$k = 0; 
    for ($i=0; $i<strlen($txt); $i++) { 
        $k = $k == strlen($mdKey) ? 0 : $k; 
        $j = ($nh+strpos($chars,$txt[$i])+ord($mdKey[$k++]))%64; 
        $tmp .= $chars[$j]; 
    } 
    return urlencode(base64_encode($ch.$tmp)); 
} 
//解密函數(shù) 
function unlock_url($txt,$key='str'){ 
    $txt = base64_decode(urldecode($txt)); 
    $chars = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-=+"; 
    $ch = $txt[0]; 
    $nh = strpos($chars,$ch); 
    $mdKey = md5($key.$ch); 
    $mdKey = substr($mdKey,$nh%8, $nh%8+7); 
    $txt = substr($txt,1); 
    $tmp = ''; 
    $i=0;$j=0; $k = 0; 
    for ($i=0; $i<strlen($txt); $i++) { 
        $k = $k == strlen($mdKey) ? 0 : $k; 
        $j = strpos($chars,$txt[$i])-$nh - ord($mdKey[$k++]); 
        while ($j<0) $j+=64; 
        $tmp .= $chars[$j]; 
    } 
    return trim(base64_decode($tmp),$key); 
} 
 

4. 高效型

function passport_encrypt($txt, $key = 'liiu') {  
    srand((double)microtime() * 1000000);  
    $encrypt_key = md5(rand(0, 32000));  
    $ctr = 0;  
    $tmp = '';  
    for($i = 0;$i < strlen($txt); $i++) {  
    $ctr = $ctr == strlen($encrypt_key) ? 0 : $ctr;  
    $tmp .= $encrypt_key[$ctr].($txt[$i] ^ $encrypt_key[$ctr++]);  
    }  
    return urlencode(base64_encode(passport_key($tmp, $key)));  
}  
 
function passport_decrypt($txt, $key = 'liiu') {  
    $txt = passport_key(base64_decode(urldecode($txt)), $key);  
    $tmp = '';  
    for($i = 0;$i < strlen($txt); $i++) {  
    $md5 = $txt[$i];  
    $tmp .= $txt[++$i] ^ $md5;  
    }  
    return $tmp;  
}  
 
function passport_key($txt, $encrypt_key) {  
    $encrypt_key = md5($encrypt_key);  
    $ctr = 0;  
    $tmp = '';  
    for($i = 0; $i < strlen($txt); $i++) {  
    $ctr = $ctr == strlen($encrypt_key) ? 0 : $ctr;  
    $tmp .= $txt[$i] ^ $encrypt_key[$ctr++];  
    }  
    return $tmp;  
}  
 
 
$txt = "1";  
$key = "testkey";  
$encrypt = passport_encrypt($txt,$key);  
$decrypt = passport_decrypt($encrypt,$key);  
 
echo $encrypt."<br>";  
echo $decrypt."<br>";  
 

5. 復(fù)雜型

非常給力的authcode加密函數(shù),Discuz!經(jīng)典代碼(帶詳解)
函數(shù)authcode($string, $operation, $key, $expiry)
$string:字符串望艺,明文或密文;
$operation: DECODE表示解密悼潭,其它表示加密
$key:密匙
$expiry:有效期

function authcode($string, $operation = 'DECODE', $key = '', $expiry = 0) {    
    // 動(dòng)態(tài)密匙長(zhǎng)度,相同的明文會(huì)生成不同密文就是依靠動(dòng)態(tài)密匙    
    $ckey_length = 4;    
 
    // 密匙    
    $key = md5($key ? $key : $GLOBALS['discuz_auth_key']);    
 
    // 密匙a會(huì)參與加解密    
    $keya = md5(substr($key, 0, 16));    
    // 密匙b會(huì)用來(lái)做數(shù)據(jù)完整性驗(yàn)證    
    $keyb = md5(substr($key, 16, 16));    
    // 密匙c用于變化生成的密文    
    $keyc = $ckey_length ? ($operation == 'DECODE' ? substr($string, 0, $ckey_length): substr(md5(microtime()), -$ckey_length)) : '';    
    // 參與運(yùn)算的密匙    
    $cryptkey = $keya.md5($keya.$keyc);    
    $key_length = strlen($cryptkey);    
    // 明文阳液,前10位用來(lái)保存時(shí)間戳梁棠,解密時(shí)驗(yàn)證數(shù)據(jù)有效性,10到26位用來(lái)保存$keyb(密匙b)动雹,  
    //解密時(shí)會(huì)通過(guò)這個(gè)密匙驗(yàn)證數(shù)據(jù)完整性    
    // 如果是解碼的話焰薄,會(huì)從第$ckey_length位開始拿诸,因?yàn)槊芪那?ckey_length位保存 動(dòng)態(tài)密匙,以保證解密正確    
    $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();    
    // 產(chǎn)生密匙簿    
    for($i = 0; $i <= 255; $i++) {    
        $rndkey[$i] = ord($cryptkey[$i % $key_length]);    
    }    
    // 用固定的算法塞茅,打亂密匙簿亩码,增加隨機(jī)性,好像很復(fù)雜野瘦,實(shí)際上對(duì)并不會(huì)增加密文的強(qiáng)度    
    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;    
        // 從密匙簿得出密匙進(jìn)行異或描沟,再轉(zhuǎn)成字符    
        $result .= chr(ord($string[$i]) ^ ($box[($box[$a] + $box[$j]) % 256]));    
    }    
    if($operation == 'DECODE') {   
        // 驗(yàn)證數(shù)據(jù)有效性,請(qǐng)看未加密明文的格式    
        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 {    
        // 把動(dòng)態(tài)密匙保存在密文里鞭光,這也是為什么同樣的明文吏廉,生產(chǎn)不同密文后能解密的原因    
        // 因?yàn)榧用芎蟮拿芪目赡苁且恍┨厥庾址瑥?fù)制過(guò)程可能會(huì)丟失惰许,所以用base64編碼    
        return $keyc.str_replace('=', '', base64_encode($result));    
    }    
}  
 
$str = 'abcdef';  
$key = 'www.telidy.com';  
echo authcode($str,'ENCODE',$key,0); //加密  
$str = '56f4yER1DI2WTzWMqsfPpS9hwyoJnFP2MpC8SOhRrxO7BOk';  
echo authcode($str,'DECODE',$key,0); //解密  
 

6. 難度型

函數(shù)encrypt($string,$operation,$key)
$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));  
    }  
}  
 
$str = 'abc';  
$key = 'www.telidy.com';  
$token = encrypt($str, 'E', $key);  
echo '加密:'.encrypt($str, 'E', $key);  
echo '解密:'.encrypt($str, 'D', $key); 
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末汹买,一起剝皮案震驚了整個(gè)濱河市佩伤,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌卦睹,老刑警劉巖畦戒,帶你破解...
    沈念sama閱讀 219,039評(píng)論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件方库,死亡現(xiàn)場(chǎng)離奇詭異结序,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī)纵潦,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,426評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門徐鹤,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)垃环,“玉大人,你說(shuō)我怎么就攤上這事返敬∷熳” “怎么了?”我有些...
    開封第一講書人閱讀 165,417評(píng)論 0 356
  • 文/不壞的土叔 我叫張陵劲赠,是天一觀的道長(zhǎng)涛目。 經(jīng)常有香客問(wèn)我,道長(zhǎng)凛澎,這世上最難降的妖魔是什么霹肝? 我笑而不...
    開封第一講書人閱讀 58,868評(píng)論 1 295
  • 正文 為了忘掉前任,我火速辦了婚禮塑煎,結(jié)果婚禮上沫换,老公的妹妹穿的比我還像新娘。我一直安慰自己最铁,他們只是感情好讯赏,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,892評(píng)論 6 392
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著冷尉,像睡著了一般漱挎。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上雀哨,一...
    開封第一講書人閱讀 51,692評(píng)論 1 305
  • 那天识樱,我揣著相機(jī)與錄音,去河邊找鬼震束。 笑死怜庸,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的垢村。 我是一名探鬼主播割疾,決...
    沈念sama閱讀 40,416評(píng)論 3 419
  • 文/蒼蘭香墨 我猛地睜開眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼嘉栓!你這毒婦竟也來(lái)了宏榕?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,326評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤侵佃,失蹤者是張志新(化名)和其女友劉穎麻昼,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體馋辈,經(jīng)...
    沈念sama閱讀 45,782評(píng)論 1 316
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡抚芦,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,957評(píng)論 3 337
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片叉抡。...
    茶點(diǎn)故事閱讀 40,102評(píng)論 1 350
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡尔崔,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出褥民,到底是詐尸還是另有隱情季春,我是刑警寧澤,帶...
    沈念sama閱讀 35,790評(píng)論 5 346
  • 正文 年R本政府宣布消返,位于F島的核電站载弄,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏撵颊。R本人自食惡果不足惜侦锯,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,442評(píng)論 3 331
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望秦驯。 院中可真熱鬧尺碰,春花似錦、人聲如沸译隘。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,996評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)固耘。三九已至题篷,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間厅目,已是汗流浹背番枚。 一陣腳步聲響...
    開封第一講書人閱讀 33,113評(píng)論 1 272
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留损敷,地道東北人葫笼。 一個(gè)月前我還...
    沈念sama閱讀 48,332評(píng)論 3 373
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像拗馒,于是被迫代替她去往敵國(guó)和親路星。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,044評(píng)論 2 355

推薦閱讀更多精彩內(nèi)容