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

            Codejie's C++ Space

            Using C++

            LAC : The secret of ld2


                這幾個晚上(周末除外)都在分解Lingoes-Extractor作者的另外一個工程的代碼, 同樣是用于分析LD2文件的,但僅僅一個java文件就搞定了,對于我這樣的JAVA初學者來說真是'太好了'...
                
                從第一次找到Extractor的代碼起,我就一直很懷疑這位作者要不跟Lingoes有點關系,要不就是一位真正的破解大師...因為Extractor太完美了...代碼不多,卻非常清晰地標記并分解出了LD2的各個段的數據,以及數據間的關系...我的懷疑來自其對ld2文件格式的認識,每一段,每一個字節的意義都非常地準確地標示出來,更神奇的是那些'無從追蹤'的魔數, 例如, 單詞索引間隔固定為10, 14字節的索引數據塊,等等...這些都是怎么推到出來的啊...

                我對自己的懷疑更偏向于后者,因為通過查看作者的其他代碼,其除了分解了ld2文件外,還包括其他多個詞典的數據文件...(感到震驚的同學們,自己去圍觀吧...另,多說一句,googlecode.com是個好地方...)

                我并不關心懷疑本身的答案, 因為我已經非常開心 --Extractor終讓我有機會窺視到Lingoes的ld2文件的秘密...

                貼段代碼, 以'獎勵'自己多夜的敲敲打打...(是我寫的Java代碼,表認真啊...)

                private static void getData(final int index) throws IOException {

                    RandomAccessFile file = new RandomAccessFile("output.data", "r");
                    final ByteBuffer buf = ByteBuffer.allocate((int) file.getChannel().size());
                    file.getChannel().read(buf);
                    buf.order(ByteOrder.LITTLE_ENDIAN);
                    int offset = 29;
                    final int idx[] = new int[6];//        
                    getIndex(buf, offset * 10, idx);

                    if(idx[5] != idx[1]) {
                        Output("self xml = " + getXml(buf, idx[1], idx[5] - idx[1]));
                    }
                    if(idx[3] == 0) {
                        Output("word = " + getWord(buf, idx[0], idx[4] - idx[0]));
                    }
                    else {
                        int ref = idx[3];
                        int offsetword = idx[0];
                        final int lenword = idx[4] - idx[0];
                        
                        while(ref -- > 0) {
                            offset = buf.getInt(lenInflatedWordsIndex + idx[0]);
                            getIndex(buf, offset * 10, idx);
                            Output("ref(" + offset + ") xml = " + getXml(buf, idx[1], idx[5] - idx[1]));
                            offsetword += 4;
                        }
                        Output("word = " + getWord(buf, offsetword, lenword));
                    }

                    file.close();
                }


                再整理幾天,要能琢磨個LAC2直接使用ld2的法子來的話,那就又可以進一大步了啊...

            posted on 2012-12-03 23:14 codejie 閱讀(2439) 評論(4)  編輯 收藏 引用 所屬分類: 輪子精神LingosHook

            評論

            # re: LAC : The secret of ld2 2012-12-04 15:00 augustheart

            反編譯一定程度上來說主要還是體力活吧。  回復  更多評論   

            # re: LAC : The secret of ld2[未登錄] 2012-12-04 21:54 codejie

            @augustheart
            這個我同意,但首先你得會反編譯...像我這樣不懂的,只能一個一個字節分解Data文件了...NND,這更是體力活...  回復  更多評論   

            # re: LAC : The secret of ld2[未登錄] 2014-02-09 09:24 Alex

            博主能不能寫一個LD2查詢的java庫啊。這樣大家就都可以用了  回復  更多評論   

            # re: LAC : The secret of ld2 2014-02-09 16:39 codejie

            @Alex
            實在對不起啊, 現在還真沒時間..如果你需要這個, 建議看看Extractor工程, 那段代碼很簡單的.  回復  更多評論   

            公告

            Using C++

            導航

            統計

            留言簿(73)

            隨筆分類(513)

            積分與排名

            最新評論

            閱讀排行榜

            評論排行榜

            韩国三级中文字幕hd久久精品 | 久久精品国产精品亚洲毛片 | 国内精品伊人久久久久影院对白| 一本一本久久A久久综合精品| 伊人久久久AV老熟妇色| 久久久噜噜噜久久中文福利| 成人国内精品久久久久影院VR| 午夜肉伦伦影院久久精品免费看国产一区二区三区 | 久久久一本精品99久久精品88| 9久久9久久精品| 少妇久久久久久被弄到高潮| 亚洲午夜久久久久妓女影院| 99久久夜色精品国产网站| 日韩欧美亚洲综合久久 | 五月丁香综合激情六月久久 | 久久精品无码av| 久久精品亚洲中文字幕无码麻豆| 7国产欧美日韩综合天堂中文久久久久 | 国内精品欧美久久精品| 色欲久久久天天天综合网| 久久久WWW成人免费精品| 国内精品人妻无码久久久影院| 中文精品久久久久人妻| 日本精品久久久中文字幕| 久久婷婷五月综合色高清| 一本大道久久东京热无码AV| 狠狠色综合网站久久久久久久| 久久精品国产网红主播| 亚洲精品乱码久久久久久蜜桃图片 | 国产精品久久久久久久久软件| 久久久精品免费国产四虎| 久久久久人妻精品一区| 蜜桃麻豆WWW久久囤产精品| 伊人久久一区二区三区无码| 久久精品亚洲福利| 国产精品美女久久久久AV福利| 69国产成人综合久久精品| 国产产无码乱码精品久久鸭| 精品久久久久香蕉网| 久久九九亚洲精品| 久久精品亚洲男人的天堂|