主頁 > 知識庫 > XXencode 編碼,XX編碼介紹、XXencode編碼轉(zhuǎn)換原理與算法

XXencode 編碼,XX編碼介紹、XXencode編碼轉(zhuǎn)換原理與算法

熱門標簽:熱血傳奇沃瑪森林地圖標注 南召400電話辦理資費 福建ai電銷機器人加盟公司 地圖標注植物名稱 去哪里辦卡 地圖標注審核工作怎么樣注冊 無錫電銷機器人銷售 招聘信息 揭陽外呼系統(tǒng)公司 鄭州中國移動400電話申請

Xxencode編碼,也是一個二進制字符轉(zhuǎn)換為普通打印字符方法。跟UUencode編碼原理方法很相似,唯獨不同的是可打印字符不同。通個UUencode編碼,我們知道它有個缺點就是,64個可打印字符中,有很多的特殊字符。而XXencode編碼方法,對64個原字符有做規(guī)范。這里它有跟Base64類型了。都有指定可打印字符范圍、及編號。Xxencode編碼在上世紀后期,IBM大型機中得到很廣泛的應(yīng)用?,F(xiàn)在逐漸被Base64編碼轉(zhuǎn)換方法所取代了。

Xxencode編碼原理

XXencode將輸入文本以每三個字節(jié)為單位進行編碼。如果最后剩下的資料少于三個字節(jié),不夠的部份用零補齊。這三個字節(jié)共有24個Bit,以6bit為單位分為4個組,每個組以十進制來表示所出現(xiàn)的數(shù)值只會落在0到63之間。以所對應(yīng)值的位置字符代替。它所選擇的可打印字符是:+-0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz,一共64個字符。跟base64打印字符相比,就是uuencode多一個“-” 字符,少一個”/” 字符。 但是,它里面字符順序與Base64完全不一樣。與UUencode比較,這里面所選擇字符,都是常見字符,沒有特殊字符。這也決定它當年流行使用原因!

每60個編碼輸出(相當于45個輸入字節(jié))將輸出為獨立的一行,每行的開頭會加上長度字符,除了最后一行之外,長度字符都應(yīng)該是“h”這個字符(45,剛好是64字符中,第45位'h'字符),最后一行的長度字符為剩下的字節(jié)數(shù)目 在64字符中位置所代表字符。

問題:uuencode編碼轉(zhuǎn)換為xxencode編碼怎么樣操作?

從2中編碼原理來看,幾乎一樣。就是所用的64個字符不一樣。一次,簡單對uuencode轉(zhuǎn)換后字符,逐位(處理'`'字符)減去32,然后得到一個值。這個值在xxencode 64字符中所對應(yīng)位置字符替換即可。

XXencode編碼轉(zhuǎn)換過程

原始字符 C a t
原始ASCII碼(十進制) 67 97 116
ASCII碼(二進制) 0 1 0 0 0 0 1 1 0 1 1 0 0 0 0 1 0 1 1 1 0 1 0 0
新的十進制數(shù)值 16 54 5 52
編碼后的XXencode字符 E q 3 O
字符串:'Cat‘ 編碼后是:Eq3O

XXencode編碼PHP實現(xiàn)過程

/**
 *xxencode編碼*
 *@author 程默
 *@copyright http://blog.chacuo.net/
 *@param string $src 待處理字符串
 *@return string encode編碼完字符串
 */
function c_xx_encode($src)
{
	//64個可打印字符
	static $base="+-0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz";
 ///每次讀取3個字節(jié)
 $lbyte = 3;
 ////將原始的3個字節(jié)轉(zhuǎn)換為4個字節(jié)
 $slen=strlen($src);
 $smod = ($slen%$lbyte);
 $snum = floor($slen/$lbyte);
 
 
 $desc = array();
 
 //將剩下字節(jié)以0字節(jié)補齊
 $src = $smod===0?$src:$src.str_repeat("\0",$lbyte-$smod);
 $snum = $smod===0?$snum:$snum+1;
 
 for($i=0;$i$snum;$i++)
 {
 ////讀取3個字節(jié)
 $_arr = array_map('ord',str_split(substr($src,$i*$lbyte,$lbyte)));
 
 ///計算每一個6位值
 $_dec = array();
 $_dec[]=$_arr[0]>>2;
 $_dec[]=(($_arr[0]3)4)|($_arr[1]>>4);
 $_dec[]=(($_arr[1]0xF)2)|($_arr[2]>>6);
 $_dec[]=$_arr[2]63;
  
 ///求每一位值,在64字符中所對應(yīng)的字符
 foreach ($_dec as $v)
 {
  $v=$base[$v];
 }
 $desc = array_merge($desc,$_dec);
 }
 

 //每60個編碼輸出(相當于45個輸入字節(jié))將輸出為獨立的一行,每行的開頭會加上長度字符,除了最后一行之外,長度字符都應(yīng)該是'h'這個ASCII字符(45),最后一行的長度字符為剩下的字節(jié)數(shù)目,在64字符中對應(yīng)字符。
 $abyte = 60;
 $crlf = "\r\n";
 $alen = count($desc);
 $anum = floor($alen/$abyte);
 $amod = ($alen%$abyte);
 
 $adesc = array();
 
 for ($i=0;$i$anum;$i++)
 {
 $adesc[]='h'.implode('',array_slice($desc,$i*$abyte,$abyte)).$crlf;
 }
 
 ///截取后面剩余數(shù)組長度
 if($amod!==0)
 {
 ///以下計算不滿45字節(jié)編碼情況
 $adesc[]=$base[$amod/4*$lbyte+($smod?$smod-$lbyte:$smod)].implode('',array_slice($desc,-$amod)).$crlf;
 }
 
 return implode('',$adesc); 
}

以上代碼從uuencode編碼做簡單修改而來,基本上去掉+32一些地方。知道編碼原理,其實我們很容易實現(xiàn)uuencode->xxencode轉(zhuǎn)換的

以上轉(zhuǎn)換后結(jié)果,與專業(yè)轉(zhuǎn)換工具一致的。好了,通過學習這類用可打印字符表示二進制字節(jié)的編碼方法。我們可以發(fā)現(xiàn)很多有趣東西!對應(yīng)以后我們?nèi)绻鲎约旱木幋a轉(zhuǎn)換,可以給我們很多借鑒!歡迎朋友們給出自己的意見!

標簽:黔南 鹽城 桂林 南昌 東莞 景德鎮(zhèn) 文山 宣城

巨人網(wǎng)絡(luò)通訊聲明:本文標題《XXencode 編碼,XX編碼介紹、XXencode編碼轉(zhuǎn)換原理與算法》,本文關(guān)鍵詞  XXencode,編碼,介紹,轉(zhuǎn)換,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《XXencode 編碼,XX編碼介紹、XXencode編碼轉(zhuǎn)換原理與算法》相關(guān)的同類信息!
  • 本頁收集關(guān)于XXencode 編碼,XX編碼介紹、XXencode編碼轉(zhuǎn)換原理與算法的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章