一区二区久久-一区二区三区www-一区二区三区久久-一区二区三区久久精品-麻豆国产一区二区在线观看-麻豆国产视频

JS幻想 讀取二進(jìn)制文件第1/2頁(yè)

且不說(shuō)瀏覽器內(nèi)置的HTTP插件是否支持二進(jìn)制數(shù)據(jù)流,就JavaScript其自身就毫無(wú)二進(jìn)制的處理能力。聰明的讀者也許想說(shuō)用VBScript就可以實(shí)現(xiàn)了。不錯(cuò),因?yàn)閂BScript,IE,ActiveX都是微軟的產(chǎn)物,所以他們有著無(wú)縫的結(jié)合。IE的HTTP組件確實(shí)能夠讀取二進(jìn)制數(shù)據(jù),而且也只能夠讓VBScript讀取。但對(duì)于其他瀏覽器,就束手無(wú)策了。

畢竟腳本的理念僅僅是用來(lái)處理一些簡(jiǎn)單的交互的,對(duì)于處理字節(jié)流之類的復(fù)雜問題完全不該是腳本的職責(zé)。不過(guò)作為一種探索,我們還是可以挖掘下其中的樂趣。當(dāng)然,首先要明確的是,對(duì)于二進(jìn)制的讀取JS確實(shí)是無(wú)能為力的,不過(guò)我們可以來(lái)模擬,以達(dá)到相同的效果,下面就跟著我來(lái)吧。

比如現(xiàn)在想要做個(gè)推箱子的小游戲,共200關(guān)。這時(shí)唯一值得考慮到事就出現(xiàn)了:把這200關(guān)地圖數(shù)據(jù)保存在何處?如果直接硬塞在一個(gè)腳本文件里似乎顯得太大,或者單獨(dú)保存在一個(gè)文件里,但是用什么格式。。。不過(guò)對(duì)于推箱子游戲來(lái)說(shuō)簡(jiǎn)單的文本格式也夠了,但對(duì)于一些地圖較復(fù)雜的也許就會(huì)使用BASE64編碼,然后由客戶端的HTTP組件下載下來(lái)解碼使用。BASE64編碼在JS中還是很常用的,畢竟它不受任何的環(huán)境限制,能夠處理字符串就行。

既然有個(gè)BASE64,那為什么就不能有BASE128,BASE256了呢?如果能實(shí)現(xiàn)“BASE256”,豈不就是二進(jìn)制字節(jié)流了?如果真可以如此,那這種方法早就流傳開了,還留著那么多的BASE64做什么:)畢竟這是字符串,而不叫字節(jié)串,那肯定是有區(qū)別的。不妨把一個(gè)二進(jìn)制的文件,當(dāng)作文本文件讀取回來(lái)試試,很快你就會(huì)發(fā)現(xiàn)超過(guò)一旦文件中出現(xiàn)127(0x7F)以上的字符,馬上就出錯(cuò)了;如果存在個(gè)0x00字節(jié)的話,后面的內(nèi)容都會(huì)蕩然無(wú)存,這意味著256個(gè)字符中能夠利用的還不到一半。

然而,可別忘了這個(gè)測(cè)試使用的僅僅是最基本的ASCII編碼,對(duì)于功能強(qiáng)大的XMLHTTP支持的也絕不僅限于如此,那么就試試Unicode字符會(huì)怎樣。在記事本隨便輸幾個(gè)字符,保存為Unicode格式的文本文件。這時(shí)用XMLHTTP讀取,顯示出來(lái)的與記事本里的一模一樣,但是再用16進(jìn)制編輯器打開此文件時(shí),就大不相同了。在文件的開頭出現(xiàn)了FF FE兩字節(jié),后面的每個(gè)內(nèi)容都是由一個(gè)0隔開。畢竟這是16位的Unicode字符,除了基本的ASCII外,還要保存各國(guó)的文字。例如一個(gè)中文就占用了2個(gè)字節(jié),而英文數(shù)字仍然占用2字節(jié),只是高位由0填充罷了(注意高位字節(jié)是在低位字節(jié)后面的)。
XMLHTTP能夠成功顯示出來(lái)就說(shuō)明Unicode還是支持的?,F(xiàn)在試著修改文件里面的數(shù)據(jù),看看超過(guò)了那些范圍才會(huì)出錯(cuò)。把數(shù)據(jù)修改成如下:FFFE 0001 0203 7F00 8000 8100 FF00 FFFF。用XMLHTTP測(cè)試,雖然顯示的都是亂碼,但并沒出錯(cuò),返回的字符串用charCodeAt(i)及toString(16)方法一試,原形畢露!幾經(jīng)測(cè)試,Unicode并不像ASCII那樣有范圍限制,但唯獨(dú)一個(gè)例外:0x0000!
眾所周知,0x00就是ASCII的結(jié)束標(biāo)志。但到了Unicode的世界里一切都是16位的,因此字符尾也成了0x0000。到了這里似乎有點(diǎn)遺憾,但接著的目標(biāo)很明確:如果能夠去掉文件中的0x0000,并在之前加上0xFEFF,就能夠讓JavaScript讀取了。

去掉以及恢復(fù),不妨就稱他編碼與解碼吧。編碼的方法就見智見仁了,最簡(jiǎn)單的辦法就是記錄下每個(gè)0x0000的位置,然后除去;在客戶端按照記錄的位置再?gòu)?fù)原回去。雖然簡(jiǎn)單,但也別忘了,0x00在二進(jìn)制文件中是相當(dāng)多的,即便是0x0000也是。這樣光是記錄他們的內(nèi)容就有很多,顯然不是很好。既然說(shuō)到要記錄,為何一定要記錄0x0000的位置?反過(guò)來(lái)想,我們應(yīng)該記錄這個(gè)文件中出現(xiàn)次數(shù)最少的字符,以及它的位置,然后把0x0000的地方替換成這個(gè)字符;解碼的時(shí)候一旦出現(xiàn)這個(gè)字符,但當(dāng)前位置又不在記錄中,就可以確定這就是個(gè)0x0000。事實(shí)上,在64K以下的文件中肯定有個(gè)字符根本就不會(huì)出現(xiàn)的(為什么仔細(xì)考慮下就明白),即使是在64K以上,還是有非常多的文件不存在某個(gè)字符的。畢竟一個(gè)Unicode字符有65536之多,很少有文件會(huì)把他們?nèi)加蒙?,除非是個(gè)冗余極小的壓縮文件,但也不會(huì)很多。

到此,編碼解碼思路已明了,剩下自然是實(shí)現(xiàn)他們。
剛才提到了源文件中出現(xiàn)最少(甚至是沒有)的Unicode字符,不妨就稱作key
首先來(lái)定義新生成的二進(jìn)制文件頭格式:
復(fù)制代碼 代碼如下:
00 01 0xFEFF。 Unicode文件頭,這是必須的
02 03 Key值。 為了不讓0x0000成為Key,在尋找的過(guò)程中忽略0x0000
03 04 Key出現(xiàn)的次數(shù)+1。 +1是為了避免該位置出現(xiàn)0x0000,后面的也都一樣
05 06
07 08 第1個(gè)Key的位置 用4字節(jié)保存每個(gè)Key的位置。
09 0A
0B 0C 。。。
0D 0E
0F 10 第n個(gè)Key的位置
11 12 文件數(shù)據(jù)內(nèi)容。。。

JavaScript技術(shù)JS幻想 讀取二進(jìn)制文件第1/2頁(yè),轉(zhuǎn)載需保留來(lái)源!

鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標(biāo)記有誤,請(qǐng)第一時(shí)間聯(lián)系我們修改或刪除,多謝。

主站蜘蛛池模板: 国产精品区网红主播在线观看 | 婷婷丁香在线观看 | 成人免费观看视频高清视频 | 久久精品国产福利 | 欧美一区二区三区gg高清影视 | sihu国产午夜精品一区二区三区 | 国产剧情一区二区 | 国产精品福利片 | 亚洲精品人人 | 蝴蝶色综合综合成人网 | 久久精品影院永久网址 | 色女人综合 | 91久久线看在观草草青青 | 欧美激情一区二区三区在线播放 | 色呦呦网站在线观看 | 久久亚洲精品玖玖玖玖 | 2021最新久久久视精品爱 | 91精品啪在线观看国产18 | 福利在线国产 | 欧美人体xxxx | 91亚洲国产成人久久精品网站 | 亚洲午夜国产精品无卡 | 一级做a爰片久久毛片一 | 色综合久久六月婷婷中文字幕 | 精品视频在线免费 | 久久九九国产精品怡红院 | 成人在色线视频在线观看免费大全 | 在线免费一区 | 色爱天堂 | 国产真实一区二区三区 | 韩国毛片视频 | 国产福利在线视频 | 免费在线视频一区 | 国产欧美一区二区三区在线 | 国产精品区网红主播在线观看 | 国产一区成人 | 国产亚洲精品九九久在线观看 | 欧美日韩亚洲国产一区二区三区 | 黄色网 在线播放 | 加勒比色综合 | www.色在线|