這篇文章主要介紹了php實(shí)現(xiàn)encode64編碼類(lèi),實(shí)例分析了php實(shí)現(xiàn)encode64編碼的技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下
本文實(shí)例講述了php實(shí)現(xiàn)encode64編碼類(lèi)。分享給大家供大家參考。具體如下:
encode64可以獲得最短的由26個(gè)英文大小寫(xiě)字母數(shù)字加上"-_"兩個(gè)符號(hào)編碼的數(shù)據(jù), 這個(gè)個(gè)字串可以在網(wǎng)絡(luò)自由傳輸, 無(wú)需考慮被自動(dòng)轉(zhuǎn)碼引起的混亂. 缺點(diǎn): 對(duì)于大字串太慢了, 原因不明, 可能PHP腳本本身就是慢, 所以它內(nèi)置 很多函數(shù), 這些函數(shù)如果用腳本來(lái)實(shí)現(xiàn)是不可忍受的. 而JavaScript就沒(méi)這個(gè)問(wèn)題, 腳本的速度快的多.
<?PHP
//encode64編碼可以同時(shí)取代encodeURI,encodeURIComponent,endode函數(shù)
//因?yàn)檫x取的這些字符都不會(huì)被編碼.
class Encode64{
function code($str) {
$KEY = 'PaAwO65goUf7IK2vi9-xq8cFTEXLCDY1Hd3tV0ryzjbpN_BlnSs4mGRkQWMZJeuh';
$a = StrToBytes($str);
$len = count($a);
$res = $len % 3;
$s = "";$i = 2;$v = 0;
for (; $i < $len; $i += 3) {
$v = $a[$i - 2] + ($a[$i - 1] << 8) + ($a[$i] << 16);
$s .= $KEY[$v & 0x3f];
$s .= $KEY[($v >> 6) & 0x3f];
$s .= $KEY[($v >> 12) & 0x3f];
$s .= $KEY[($v >> 18)];
}
if ($res == 1) {
$v = $a[$i - 2];
$s .= $KEY[$v & 0x3f];
$s .= $KEY[($v >> 6) & 0x3f];
} else if ($res == 2) {
$v = $a[$i - 2] + ($a[$i - 1] << 8);
$s .= $KEY[$v & 0x3f];
$s .= $KEY[($v >> 6) & 0x3f];
$s .= $KEY[($v >> 12) & 0x3f];
}
return $s;
}
function decode($codeStr) {
$KEY = 'PaAwO65goUf7IK2vi9-xq8cFTEXLCDY1Hd3tV0ryzjbpN_BlnSs4mGRkQWMZJeuh';
$dic = array();
for ($i = 0; $i < 64; $i++) {
$dic[$KEY[$i]] = $i;
}
$len = strlen($codeStr);
$res = $len % 4;
$cLen = floor($len/4)*3;
if($res==2) $clen += 1;
elseif($res==3) $clen += 2;
$code = range(0,$clen);
$i = 3;$v = 0; $j = 0;
for (; $i < $len; $i += 4) {
$v = $dic[$codeStr[$i - 3]];
$v += $dic[$codeStr[$i - 2]] << 6;
$v += $dic[$codeStr[$i - 1]] << 12;
$v += $dic[$codeStr[$i]] << 18;
$code[$j] = $v & 0xff;
$code[$j+1] = ($v >> 8) & 0xff;
$code[$j+2] = ($v >> 16) & 0xff;
$j += 3;
}
if ($res == 2) {
//正確的字節(jié)數(shù)肯定是余2或3, 沒(méi)有1的情況, 如果出現(xiàn), 舍棄.
$v = $dic[$codeStr[$i - 3]];
$v += $dic[$codeStr[$i - 2]] << 6;
$code[$j] = $v & 0xff;
} else if ($res == 3) {
$v = $dic[$codeStr[$i - 3]];
$v += $dic[$codeStr[$i - 2]] << 6;
$v += $dic[$codeStr[$i - 1]] << 12;
$code[$j] = $v & 0xff;
$code[$j+1] = ($v >> 8) & 0xff;
}
return BytesToStr($code);
}
}
function BytesToStr($bytes) {
$str = '';
foreach($bytes as $ch) {
$str .= chr($ch);
}
return iconv('UTF-16BE','utf-8',$str);
}
function StrToBytes($str) {
$str = iconv('utf-8','UTF-16BE',$str);
$len = strlen($str);
$bytes = array();
for($i=0;$i<$len;$i++) {
$bytes[] = ord($str[$i]) ;
}
return $bytes;
}
?>
希望本文所述對(duì)大家的php程序設(shè)計(jì)有所幫助。
更多信息請(qǐng)查看IT技術(shù)專(zhuān)欄