(转)百度文库浏览器分析及实现(续)
這個是DotNet動態模擬的實現頁面:http://download.csdn.net/source/2153964
文庫系統已經開發完成了,包括上傳,動態轉換,以及符合百度文庫的資源文件的生成,打分,統計,收藏等功能
(由于項目的關系不能公開項目代碼,當前示例,僅包含顯示,不包含數據庫,上傳,動態轉換,資源文件生成等內容)
這里就簡單的介紹一下整個流程及原理。
首先,反編譯 百度文庫Flash瀏覽器用的軟件是Sothink SWF Decompiler,不過你會發現反編譯的代碼還是有很多錯誤的;當然您可以逐步將代碼進行修改,以達到使用的需要(這里我僅僅是使用這個Flash本身,采用反編譯器僅為分析文庫資源文件格式)。
其次,需要通過Flash的代碼分析百度文庫動態裝載的資源文件的文件格式 ,在文件DocViewer.as中事件響應函數binaryLoadComplete中,仔細讀這一段您就可以分析清楚百度文庫的資源文件格式了,這里我就不完整的敘述了。
view plaincopy 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;??
}// end function?
??????? 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;
??????? }// end function
到目前知道了百度的資源文件格式,也能實現文件的動態顯示,接下來就是需要實現文檔的上傳以及轉換等操作
上傳 ,可以用百度默認的上傳flash,也可以使用第三方的上傳flash,這里有很多通用的flash上傳控件,只是在dotnet中接收大文件時需要修改iis的相關配置。
上傳到服務器后,首先采用數據庫記錄上傳的文件以及關聯用戶(或許這里面您需要為文庫建立 模型 了)
接下來需要進行的處理就是將任意文檔轉換為PDF ,這里面可以使用的有國外免費使用的PDF Convert 虛擬打印機,當然也有付費版本的
根據系統的情況確定是自動轉換為PDF,還是需要人工審核 ,百度采用的是人工審核的方式
之后需要做的事情就是將PDF轉換為FlashPaper ,這里面需要您認真領會上面一段代碼,然后將文檔組織成為百度文庫Flash支持的文檔格式,暫時稱為SWFX吧,關于這個文件格式的描述,在一段時間后我將公開他
最后需要做的事情就是將轉換的SWFX存儲,結合后來裝載資源文件的規則進行命名及存儲
所有的核心步驟就是這樣的,不過這里面有一個問題就是虛擬打印機的效率還是很低的,PDF轉換為FlashPaper的轉換效率也是馬馬虎虎,可以考慮將這兩項工作交由windows服務 來實現
也就是說需要使用C#開發一個windows服務來對審核通過的文檔進行兩次轉換工作。
本文來自CSDN博客,轉載請標明出處:http://blog.csdn.net/chinull/archive/2010/04/19/5503397.aspx
轉載于:https://www.cnblogs.com/cwfsoft/archive/2010/05/05/1728152.html
總結
以上是生活随笔為你收集整理的(转)百度文库浏览器分析及实现(续)的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: f60gen command
- 下一篇: Fckeditor配置 for ASP.