http://blog.csdn.net/chinull/archive/2010/04/19/5503397.aspx
這個是DotNet動態模擬的實現頁面:http://download.csdn.net/source/2153964
文庫系統已經開發完成了,包括上傳,動態轉換,以及符合百度文庫的資源文件的生成,打分,統計,收藏等功能
(由于項目的關系不能公開項目代碼,當前示例,僅包含顯示,不包含數據庫,上傳,動態轉換,資源文件生成等內容)
這里就簡單的介紹一下整個流程及原理。
首先,反編譯 百度文庫Flash瀏覽器用的軟件是Sothink SWF
Decompiler,不過你會發現反編譯的代碼還是有很多錯誤的;當然您可以逐步將代碼進行修改,以達到使用的需要(這里我僅僅是使用這個Flash本
身,采用反編譯器僅為分析文庫資源文件格式)。
其次,需要通過Flash的代碼分析百度文庫動態裝載的資源文件的文件格式
,在文件DocViewer.as中事件響應函數binaryLoadComplete中,仔細讀這一段您就可以分析清楚百度文庫的資源文件格式了,這里
我就不完整的敘述了。
copy
to clipboardprint?
- private function binaryLoadComplete(event:Event = null) : void
- {
- var _loc_11:ByteArray = null;
- var _loc_12:int = 0;
- trace("binaryLoadComplete...");
- if (this._noDoc)
- {
- if (this._noDoc.parent)
- {
- this._noDoc.parent.removeChild(this._noDoc);
- }
- this._noDoc = null;
- }
- this._loadPercent = 0;
- var _loc_2:* = URLLoader(event.target);
- var _loc_3:* = _loc_2.data;
- this._byteArray = [];
- var _loc_4:Array = [];
- var _loc_5:int = 0;
- var _loc_6:* = _loc_3.length;
- while (_loc_5 < _loc_6)
- {
-
- if (_loc_5 + 3 < _loc_6)
- {
- if ((_loc_3[_loc_5] == 67 || _loc_3[_loc_5] == 70) && _loc_3[(_loc_5 + 1)] == 87 && _loc_3[_loc_5 + 2] == 83 && (_loc_3[_loc_5 + 3] == 9 || _loc_3[_loc_5 + 3] == 10))
- {
- _loc_4.push(_loc_5);
- }
- }
- else
- {
- _loc_4.push(_loc_6);
- break;
- }
- _loc_5++;
- }
- var _loc_7:* = _loc_3.readMultiByte(_loc_4[0], "utf-8");
- trace(_loc_7);
- var _loc_8:* = JSON.decode(_loc_7);
- this._pagesAll = Number(_loc_8["totalPage"]);
- if (!this._pagesLoaded)
- {
- this._pagesLoaded = 0;
- }
- this._pagesLoaded = this._pagesLoaded + (Number(_loc_8["toPage"]) - Number(_loc_8["fromPage"]) + 1);
- this._fromPage = Number(_loc_8["fromPage"]);
- this._toPage = Number(_loc_8["toPage"]);
- trace("pagesall:" + this._pagesAll + " , frompage:" + this._fromPage + " , topage:" + this._toPage);
- this._pagethLoading = Number(_loc_8["fromPage"]) - 1;
- var _loc_9:int = 0;
- var _loc_10:* = _loc_4.length - 1;
- while (_loc_9 < _loc_10)
- {
-
- _loc_11 = new ByteArray();
- _loc_12 = _loc_4[(_loc_9 + 1)] - _loc_4[_loc_9];
- _loc_3.readBytes(_loc_11, 0, _loc_12);
- this._byteArray.push(_loc_11);
- _loc_9++;
- }
- trace("...............這一次加載了多少
頁:" + this._byteArray.length);
- this._hasConvertPages = 0;
- this._allConvertPages = Math.min(this._byteArray.length, this._toPage - this._fromPage + 1);
- if (this._allConvertPages > 0)
- {
- this.byteArr2DisplayObj(this._hasConvertPages);
- }
- else
- {
- trace("blank document ...");
- this.processNoDoc();
- this._loadPercent = 0;
- dispatchEvent(new Event("STOP_LOADING", true));
- this._inLoading = false;
- }
- return;
- }
到目前知道了百度的資源文件格式,也能實現文件的動態顯示,接下來就是需要實現文檔的上傳以及轉換等操作
上傳
,可以用百度默認的上傳flash,也可以使用第三方的上傳flash,這里有很多通用的flash上傳控件,只是在dotnet中接收大文件時需要修改
iis的相關配置。
上傳到服務器后,首先采用數據庫記錄上傳的文件以及關聯用戶(或許這里面您需要為文庫建立 模
型 了)
接下來需要進行的處理就是將任意文檔轉換為PDF ,這里面可以使用的有國外免費使用的PDF Convert
虛擬打印機,當然也有付費版本的
根據系統的情況確定是自動轉換為PDF,還是需要人工審核 ,百度采用的是人工審核的方式
之后需要做的事情就是將PDF轉換為FlashPaper
,這里面需要您認真領會上面一段代碼,然后將文檔組織成為百度文庫Flash支持的文檔格式,暫時稱為SWFX吧,關于這個文件格式的描述,在一段時間后
我將公開他
最后需要做的事情就是將轉換的SWFX存儲,結合后來裝載資源文件的規則進行命名及存儲
所有的核心步驟就是這樣的,不過這里面有一個問題就是虛擬打印機的效率還是很低的,PDF轉換為FlashPaper的轉換效率也是馬馬虎虎,可以
考慮將這兩項工作交由windows服務 來實現
也就是說需要使用C#開發一個windows服務來對審核通過的文檔進行兩次轉換工作。
posted on 2010-07-05 22:40
SIMONE 閱讀(3384)
評論(4) 編輯 收藏