php實現(xiàn)可逆加密的方法
更新時間:2015年08月11日 11:07:37 作者:fdwqy
這篇文章主要介紹了php實現(xiàn)可逆加密的方法,借鑒了discuz的加密原理實現(xiàn)通過密鑰進行可逆加密的功能,具有一定參考借鑒價值,需要的朋友可以參考下
本文實例講述了php實現(xiàn)可逆加密的方法。分享給大家供大家參考。具體如下:
這里介紹的可以逆轉(zhuǎn)加密類,沒有密鑰很難破解。
PHP代碼如下:
<?php
class encryptCalss
{
var $key=12;
function encode($txt){
for($i=0;$i<strlen($txt);$i++){
$txt[$i]=chr(ord($txt[$i])+$this->key);
}
return $txt=urlencode(base64_encode(urlencode($txt)));
}
function decode($txt){
$txt=urldecode(base64_decode($txt));
for($i=0;$i<strlen($txt);$i++){
$txt[$i]=chr(ord($txt[$i])-$this->key);
}
return $txt;
}
}
?>
discuz加密解密:
<?php
/**
*
* @param string $string 原文或者密文
* @param string $operation 操作(ENCODE | DECODE), 默認為 DECODE
* @param string $key 密鑰
* @param int $expiry 密文有效期, 加密時候有效, 單位 秒,0 為永久有效
* @return string 處理后的 原文或者 經(jīng)過 base64_encode 處理后的密文
* @example
* $a = authcode('abc', 'ENCODE', 'key');
* $b = authcode($a, 'DECODE', 'key'); // $b(abc)
*
* $a = authcode('abc', 'ENCODE', 'key', 3600);
* $b = authcode('abc', 'DECODE', 'key'); // 在一個小時內(nèi),$b(abc),否則 $b 為空
*/
function authcode($string,$operation='DECODE',$key='',$expiry=0){
$ckey_length=4;
$key=md5($key ? $key:"kalvin.cn");
$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)){
returnsubstr($result,26);
}else{
return'';
}
}else{
return $keyc.str_replace('=','',base64_encode($result));
}
}
?>
希望本文所述對大家的php程序設(shè)計有所幫助。
您可能感興趣的文章:
- 從零開始學(xué)YII2框架(一)通過Composer安裝Yii2框架
- 從零開始學(xué)YII2框架(五)快速生成代碼工具 Gii 的使用
- 從零開始學(xué)YII2框架(六)高級應(yīng)用程序模板
- 從零開始學(xué)YII2框架(二)通過 Composer 安裝擴展插件
- 從零開始學(xué)YII2框架(三)擴展插件yii2-gird
- 從零開始學(xué)YII2框架(四)擴展插件yii2-kartikgii
- Yii2框架引用bootstrap中日期插件yii2-date-picker的方法
- Yii2框架數(shù)據(jù)庫簡單的增刪改查語法小結(jié)
- Yii2框架中日志的使用方法分析
- PHP可逆加密/解密函數(shù)分享
- php加密算法之實現(xiàn)可逆加密算法和解密分享
- Yii2框架可逆加密簡單實現(xiàn)方法
相關(guān)文章
PHP實現(xiàn)檢測客戶端是否使用代理服務(wù)器及其匿名級別
這篇文章主要介紹了PHP實現(xiàn)檢測客戶端是否使用代理服務(wù)器及其匿名級別,需要的朋友可以參考下2015-01-01

