php實(shí)現(xiàn)encode64編碼類實(shí)例
本文實(shí)例講述了php實(shí)現(xiàn)encode64編碼類。分享給大家供大家參考。具體如下:
encode64可以獲得最短的由26個(gè)英文大小寫字母數(shù)字加上"-_"兩個(gè)符號(hào)編碼的數(shù)據(jù), 這個(gè)個(gè)字串可以在網(wǎng)絡(luò)自由傳輸, 無需考慮被自動(dòng)轉(zhuǎn)碼引起的混亂. 缺點(diǎn): 對(duì)于大字串太慢了, 原因不明, 可能PHP腳本本身就是慢, 所以它內(nèi)置 很多函數(shù), 這些函數(shù)如果用腳本來實(shí)現(xiàn)是不可忍受的. 而JavaScript就沒這個(gè)問題, 腳本的速度快的多.
<?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, 沒有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ì)有所幫助。
相關(guān)文章
php 數(shù)組的指針操作實(shí)現(xiàn)代碼
php 數(shù)組的指針操作實(shí)現(xiàn)代碼,數(shù)組在php編寫中是非常重要的操作,學(xué)習(xí)php的朋友可以參考下。2011-02-02PHP實(shí)現(xiàn)的無限分類類庫定義與用法示例【基于thinkPHP】
這篇文章主要介紹了PHP實(shí)現(xiàn)的無限分類類庫定義與用法,結(jié)合實(shí)例形式分析了基于thinkPHP實(shí)現(xiàn)的無限分類類庫相關(guān)定義及具體使用操作技巧,需要的朋友可以參考下2018-08-08php下實(shí)現(xiàn)在指定目錄搜索指定類型文件的函數(shù)
php在特定目錄中找特定類型的文件2008-10-10php中url傳遞中文字符,特殊危險(xiǎn)字符的解決方法
本文章結(jié)合php中的urldecode,base64_encode函數(shù)然后再結(jié)合自己寫的替換函數(shù)來進(jìn)行安全傳遞url中文字符,特殊危險(xiǎn)字符,有需要的朋友可以參考一下2013-08-08PHP開發(fā)中常見的安全問題詳解和解決方法(如Sql注入、CSRF、Xss、CC等)
這篇文章主要介紹了PHP開發(fā)中常見的安全問題詳解和解決方法,詳細(xì)介紹了例如Sql注入、CSRF、Xss、CC等攻擊手段的背景知識(shí)以及解決方法,需要的朋友可以參考下2014-04-04