青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

Welcome to ErranLi's Blog!

  C++博客 :: 首頁(yè) :: 聯(lián)系 :: 聚合  :: 管理
  106 Posts :: 1 Stories :: 97 Comments :: 0 Trackbacks

常用鏈接

留言簿(12)

搜索

  •  

積分與排名

  • 積分 - 178126
  • 排名 - 152

最新評(píng)論

閱讀排行榜


CHM格式解析


CHM格式有一個(gè)初始化頭,占38H字節(jié),后面是header section和到正文 段的偏移量。加在一起,這些被稱為文件頭。
header section一共有兩個(gè)section,一個(gè)是文件目錄,另一個(gè)包含著文件長(zhǎng)度和一些未知信息。
初始化頭:
前 四個(gè)字節(jié)為ITSF,第二個(gè)雙字為版本信息,第三雙字是文件頭的總長(zhǎng)度,第四雙字值為1,第五雙字是一個(gè)時(shí)間記錄,(第一個(gè)字節(jié)是MSB,第二個(gè)字節(jié)是 fractional seconds(second byte),第三個(gè)字節(jié)可并不確定,第四個(gè)字節(jié)僅能知道其符號(hào)位是確定的。)第六雙字是windows語(yǔ)言ID標(biāo)識(shí),后面16個(gè)字節(jié)是兩個(gè)連續(xù)的組ID, 分別為{7C01FD10-7BAA-11D0-9E0C-00A0-C922-E6EC}
和{7C01FD11-7BAA-11D0-9E0C-00A0-C922-E6EC}
后面是header section的表,其中有兩項(xiàng),每項(xiàng)占16個(gè)字節(jié),記錄著從文件頭開(kāi)始的偏移量和section的長(zhǎng)度,各占8個(gè)字節(jié)。
后面還有8個(gè)字節(jié)的信息,這些在版本2里是沒(méi)有的。
header section 0:
第一雙字:0x01fe
第三雙字為文件大小
共占5個(gè)雙字,其余雙字均為0
header section 1(directory header)
開(kāi)始的四個(gè)字節(jié)為ITSP,
后面的雙字為版本號(hào),
第三雙字為本section長(zhǎng)度,
第四雙字信息未知,
第五雙字值為0x1000,是目錄塊的大小,
第六雙字是quickref section的“密度”,一般是2
第七雙字是索引樹(shù)的深度,1表示沒(méi)有索引,2表示有一層的PMGI數(shù)據(jù)塊。
第八雙字表示根索引的塊號(hào),如果沒(méi)有索引為-1
第九雙字是第一個(gè)PMGL(listing)的塊號(hào)
第十雙字是最后一個(gè)PMGL的塊號(hào)
第十一雙字是-1
第十二雙字是目錄塊的塊數(shù)
第十三雙字是windows語(yǔ)言ID標(biāo)識(shí)
從這里開(kāi)始有16個(gè)字節(jié)的GUID{5D02926A-212E-11D0-9DF9-00A0C922E6EC}
然后四個(gè)雙字不知道是什么東西
本段共84個(gè)字節(jié)
從這里開(kāi)始往后都是數(shù)據(jù)塊,分為兩種,一種是列表塊(listing chunks),一種是索引塊(index chunks)其中列表塊的格式如下:
開(kāi)始是四個(gè)字節(jié)PMGL
然后的四個(gè)字節(jié)是目錄塊尾部的空白區(qū)的長(zhǎng)度或是quickref區(qū)域的長(zhǎng)度
第三雙字恒為0
第四雙字是前一個(gè)列表塊的塊號(hào),如果這是第一個(gè)塊,該值為-1
第五雙字是后一個(gè)列表塊的塊號(hào),如果這是最后一塊,該值為-1
從這里開(kāi)始是目錄列表項(xiàng),按文件名排序,并且大小寫(xiě)不分
quickref區(qū)是從數(shù)據(jù)塊的后面向前寫(xiě),每隔n個(gè)項(xiàng)出現(xiàn)一個(gè)quickref,且n的值為1+(1<<“密度”),其格式從后至前為
第一個(gè)字:整個(gè)數(shù)據(jù)塊中的項(xiàng)數(shù)
第二個(gè)字:從第0項(xiàng)到第n項(xiàng)之間的偏移量
第三個(gè)字:從第0項(xiàng)到第2n項(xiàng)之間的偏移量
以此類推
目錄列表的每一項(xiàng)的格式如下:
encint型名字長(zhǎng)度,后面是UTF-8編碼的名稱,encint型正文段,encint型偏移量,encint型長(zhǎng)度,其中偏移量是從解壓縮之后的正文段的開(kāi)始來(lái)計(jì)算的,同樣長(zhǎng)度也是表示解壓縮之后的長(zhǎng)度。
在目錄中存在兩種文件,用戶數(shù)據(jù)文件和格式信息文件,格式信息文件以兩個(gè)連續(xù)的冒號(hào)“::”開(kāi)頭,用戶數(shù)據(jù)文件以“/”開(kāi)頭。
索引塊:
前四個(gè)字節(jié)為PMGI
后面四個(gè)字節(jié)是塊尾部的quickref或是空白區(qū)的長(zhǎng)度。
從這里開(kāi)始是目錄索引項(xiàng)的開(kāi)始,每一個(gè)目錄索引項(xiàng)的結(jié)構(gòu)如下:
encint型的名稱長(zhǎng)度,UFT-8編碼的名稱,以此名稱開(kāi)始的列表塊的塊號(hào)。
quickref的格式和排列與列表塊中相同
當(dāng)有索引塊的層次較多時(shí),將不再存儲(chǔ)數(shù)據(jù)塊號(hào)而是存儲(chǔ)下一層的索引號(hào)。
解釋一下encint型變量的編碼規(guī)則:
一種可變長(zhǎng)度的整型變量,第一個(gè)字節(jié)只使用低7位,最高位為1表示該字節(jié)之后的下一字節(jié)的低7位要接在這7位的尾部組成一個(gè)數(shù),這樣通過(guò)移位相加的運(yùn)算,直到遇到最高位為0的字節(jié),可以組和成一個(gè)長(zhǎng)度可調(diào)節(jié)的整數(shù)。
正文:在版本3中,正文一般緊跟著文件頭,而且在文件頭表之后有一個(gè)雙字用來(lái)指定其位置。在版本2中,正文部分緊跟著文件頭,而且所有此文件夾中的正文部分的第0段放在都放在這個(gè)益上,其它的正文段都within content section 0
名稱列表文件:
放在content section 0中,文件名為"::DataSpace/NameList",其中包含著所有正文段的名稱,其格式如下:
第一個(gè)字:以字計(jì)數(shù)的文件長(zhǎng)度
第二個(gè)字:文件中的entry數(shù)
對(duì)于每一個(gè)entry格式為:
第一個(gè)字:以字計(jì)數(shù)的名字長(zhǎng)度,不包括最后的NULL結(jié)尾符
以word 0表示所有entry的結(jié)束。
名稱的編碼類似于UFT-16。
段的名稱目前為止只有兩種,Uncompressed和MSCompressed,分別表示自解釋文件和Microsoft LZX壓縮算法壓縮的文件。
section data:
對(duì) 于段號(hào)不為0的段,還有一個(gè)文件為::DataSpace/Storage/<Section Name>/Content,里面存放著該段的壓縮信息,所以,當(dāng)解析非0段時(shí),需要兩步工作,第一步,取得第0段并將其解圧,取得段名,第二步才 能利用段名找到相應(yīng)的段
其余與格式相關(guān)的文件:
::DataSpace/Storage/<SectionName>/ControlData
共0x20個(gè)字節(jié),存儲(chǔ)關(guān)于壓縮的信息
第一個(gè)雙字為在“LZXC”串后的雙字個(gè)數(shù),在版本2中,此值必為6
第二個(gè)雙字為“LZXC”
第三個(gè)雙字為版本信息,必須大于2
第四個(gè)雙字為L(zhǎng)ZX reset interval
第五個(gè)雙字為窗口大小
第六個(gè)雙字為緩存大小
第七個(gè)雙字為0,未知信息。
::DataSpace/Storage/<SectionName>/SpanInfo
存放著未解壓的段的長(zhǎng)度信息。
::DataSpace/Storage/<SectionName>/Transform/List
存放GUID列表用于解壓縮
壓縮段:
這 一段用LZX壓縮,要進(jìn)行解壓縮,先要讀取::DataSpace/Storage/<SectionName>/Transform/ {7FC28940-9D31-11D0-9B27-00A0C91E9C7C}/InstanceData/ResetTable,其格式如下:
第一個(gè)雙字為2,估計(jì)是版本信息
第二個(gè)雙字是reset table中的entry數(shù)
第三個(gè)雙字是8,每一個(gè)entry的大小
第四個(gè)雙字是表頭長(zhǎng)度
16個(gè)字節(jié)的壓縮前長(zhǎng)度
16個(gè)字節(jié)的壓縮后長(zhǎng)度
16個(gè)字節(jié)的0x8000 block size for locations below
16個(gè)字節(jié)的0
16個(gè)字節(jié)的第一個(gè)非壓縮數(shù)據(jù)塊的邊界在壓縮數(shù)據(jù)塊中的位置信息
注意:
There is one change from LZX as defined by Microsoft: After each LZX reset interval (defined in the ControlData file, but in practice equal to the window size) of compressed data is processed, the LZX state is fully reset, as if an entirely new file was being encoded. This allows semi-random access to the compressed data; you can start reading on any reset interval boundary using the reset interval size and the reset table.
posted on 2007-10-14 00:07 erran 閱讀(2254) 評(píng)論(5)  編輯 收藏 引用 所屬分類: Standard & Confer

Feedback

# re: CHM格式解析 2007-10-30 21:37 牛牛
說(shuō)得夠細(xì),能不能給出VB讀取的(從中讀取想要的文件)代碼,小弟學(xué)VB加網(wǎng)頁(yè)設(shè)計(jì),哪位老大給個(gè)代碼,在此謝過(guò)!偶的郵箱:liyong_sbcel@sina.com  回復(fù)  更多評(píng)論
  

# re: CHM格式解析 2007-10-30 22:25 Minidx全文檢索
這個(gè)不錯(cuò),收藏了  回復(fù)  更多評(píng)論
  

# re: CHM格式解析 2007-11-01 16:52 地方深度
謝謝  回復(fù)  更多評(píng)論
  

# re: CHM格式解析 2008-04-15 13:37 spiet
講了半天,我還是不知道正文內(nèi)容從哪里開(kāi)始的.另外如何解壓正文  回復(fù)  更多評(píng)論
  

# re: CHM格式解析 2008-12-04 18:13 reeze
可以參考這網(wǎng)站,里面有詳細(xì)的介紹。
http://www.russotto.net/chm/index.html
還有這個(gè)非官方介紹
http://savannah.nongnu.org/projects/chmspec  回復(fù)  更多評(píng)論
  

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            免费一级欧美片在线观看| 久久香蕉国产线看观看网| 欧美日韩精品一区二区三区| 鲁大师成人一区二区三区| 久久综合电影| 欧美久久久久久久久| 欧美性猛交xxxx免费看久久久 | 亚洲精品社区| 亚洲一区一卡| 久久视频在线免费观看| 欧美成人蜜桃| 国产精品福利在线观看| 激情久久五月| 亚洲视频 欧洲视频| 久久国产福利国产秒拍| 噜噜噜躁狠狠躁狠狠精品视频| 亚洲国产导航| 亚洲一区二区三| 久久久999精品| 欧美视频在线不卡| 黄色成人av| 亚洲一区二区3| 国产精品久久久久三级| 黄色成人av网| 久久亚洲图片| 国产精品日日摸夜夜摸av| 激情另类综合| 欧美亚洲在线观看| 91久久午夜| 久久视频在线看| 国产精品免费小视频| 亚洲黄色成人久久久| 午夜精品视频在线| 亚洲靠逼com| 欧美成人三级在线| 尤物网精品视频| 久久国产精品99久久久久久老狼| 欧美国产精品一区| 久久久国产精品一区| 国产精品美女在线| 在线一区二区三区四区| 欧美福利在线观看| 久久精品免费看| 国产日韩欧美一区在线| 亚洲综合色丁香婷婷六月图片| 亚洲激情网站免费观看| 麻豆成人在线观看| 在线观看日韩欧美| 久久综合久久88| 久久国产精品免费一区| 国产欧美日韩专区发布| 亚洲欧美另类综合偷拍| 一区二区日本视频| 欧美先锋影音| 亚洲欧美在线免费| 亚洲永久字幕| 国产精品日韩在线播放| 亚洲欧美一区二区三区久久| 99天天综合性| 国产精品大片wwwwww| 亚洲自拍三区| 亚洲自拍三区| 国产一区二区成人| 欧美fxxxxxx另类| 欧美成人一品| 亚洲一区二区日本| 亚洲欧美精品伊人久久| 国产视频一区在线| 美女诱惑黄网站一区| 理论片一区二区在线| 亚洲黄页一区| 99re6这里只有精品| 国产精品多人| 久久久免费av| 欧美成人情趣视频| 亚洲欧美视频一区二区三区| 香蕉成人啪国产精品视频综合网| 国产亚洲欧美另类中文| 免费高清在线一区| 欧美伦理视频网站| 久久本道综合色狠狠五月| 久久久久久久久久久久久久一区| 亚洲黄色在线看| 性欧美videos另类喷潮| 亚洲欧美一区二区激情| 影音欧美亚洲| 亚洲毛片一区| 国模精品一区二区三区色天香| 美女免费视频一区| 欧美激情视频一区二区三区不卡| 欧美极品aⅴ影院| 亚洲尤物视频网| 久久精品免费| 亚洲男人的天堂在线aⅴ视频| 久久久久久久一区二区三区| 99国产精品久久久久久久久久 | 久久爱另类一区二区小说| 亚洲电影在线播放| 中文久久精品| 亚洲国产精品久久久久婷婷884| 日韩视频二区| 亚洲国产一区二区三区高清| 在线视频欧美日韩精品| 亚洲国产精品va| 亚洲欧美制服另类日韩| 亚洲美女视频| 久久五月天婷婷| 欧美在线日韩精品| 欧美深夜影院| 亚洲国产欧美一区二区三区久久 | 亚洲国产精品一区二区久| 国产精品免费小视频| 亚洲国产小视频| 伊人久久久大香线蕉综合直播| 亚洲影院一区| 一本色道久久加勒比精品| 久久精品在线视频| 欧美一区二区三区在线免费观看| 欧美精品久久久久久久久久| 欧美肥婆bbw| 亚洲国产精品第一区二区三区| 欧美亚洲一区三区| 欧美亚洲日本网站| 国产精品久久久久9999| 欧美激情精品久久久久久大尺度| 狠狠色狠狠色综合| 久久大逼视频| 狂野欧美一区| 精品成人一区二区三区四区| 久久国产精品久久精品国产| 久久精品夜夜夜夜久久| 国产日韩精品在线| 欧美一乱一性一交一视频| 香蕉久久夜色精品国产| 国产精品免费看片| 小黄鸭精品aⅴ导航网站入口 | 久久av一区二区三区| 国产精品网站一区| 欧美一级久久久| 久久久久久久性| 在线播放中文一区| 久久这里只有| 亚洲国产清纯| 欧美成人国产| 亚洲三级免费| 亚洲免费一区二区| 国产热re99久久6国产精品| 亚洲欧美日韩另类| 浪潮色综合久久天堂| 亚洲黄网站在线观看| 欧美精品网站| 亚洲一区二区视频在线观看| 久久精品九九| 91久久精品www人人做人人爽| 欧美激情一区二区三区成人| 一本色道久久88精品综合| 午夜精品成人在线| 红桃视频一区| 欧美日韩一区二区精品| 午夜欧美大片免费观看| 欧美xart系列在线观看| 亚洲先锋成人| 狠狠干综合网| 欧美日韩精品中文字幕| 欧美一区在线直播| 最近中文字幕日韩精品| 性欧美办公室18xxxxhd| 精品51国产黑色丝袜高跟鞋| 欧美激情一区二区三区蜜桃视频 | 午夜精品久久久久久99热软件| 国产视频精品xxxx| 欧美电影在线免费观看网站 | 欧美日韩精品免费观看视一区二区 | 亚洲在线国产日韩欧美| 精品av久久久久电影| 欧美日本韩国一区二区三区| 欧美一区永久视频免费观看| 91久久精品国产91久久性色tv| 亚洲欧美一区二区精品久久久| 在线观看福利一区| 国产精品乱码一区二区三区| 噜噜噜噜噜久久久久久91| 亚洲一二三四久久| 亚洲国产99| 久久亚洲国产精品一区二区| 亚洲午夜一区二区| 亚洲国产综合91精品麻豆| 国产欧美日韩精品丝袜高跟鞋| 欧美华人在线视频| 久久久国产成人精品| 亚洲一区二区在线| 亚洲日本中文字幕免费在线不卡| 久久久久九九九九| 午夜精品剧场| 一区二区三区免费网站| 亚洲激情午夜| 亚洲第一精品夜夜躁人人躁| 国内一区二区三区在线视频| 国产精品自拍小视频| 欧美视频不卡中文|