• <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>

            Welcome to ErranLi's Blog!

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

            常用鏈接

            留言簿(12)

            搜索

            •  

            積分與排名

            • 積分 - 174947
            • 排名 - 151

            最新評(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 閱讀(2215) 評(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)論
              

            老司机国内精品久久久久| 尹人香蕉久久99天天拍| 久久精品草草草| 伊人 久久 精品| 成人综合伊人五月婷久久| 久久久久国产日韩精品网站| 99久久国产综合精品女同图片| 精品免费tv久久久久久久| 久久久久久亚洲精品影院| 久久这里只有精品久久| 国产成人精品综合久久久| AAA级久久久精品无码区| 色欲久久久天天天综合网| 久久av高潮av无码av喷吹| 久久精品水蜜桃av综合天堂| 久久伊人五月天论坛| www亚洲欲色成人久久精品| 久久精品国产99久久久| 精品久久久久久无码不卡| 国产精自产拍久久久久久蜜 | 亚洲伊人久久综合影院| 国产91色综合久久免费分享| 久久久久久亚洲精品影院| 国产精品欧美久久久久无广告| 老色鬼久久亚洲AV综合| 久久WWW免费人成一看片| 亚洲国产精品综合久久网络 | 一本大道久久a久久精品综合| 欧美午夜精品久久久久免费视 | 99久久超碰中文字幕伊人| 亚洲国产精品无码久久久蜜芽| 久久久噜噜噜久久中文字幕色伊伊| 99久久中文字幕| 久久久久久久97| 国产情侣久久久久aⅴ免费| 色欲综合久久中文字幕网| 麻豆亚洲AV永久无码精品久久| 色8久久人人97超碰香蕉987| 熟妇人妻久久中文字幕| 国产精品岛国久久久久| 99久久精品国产综合一区|