專利名稱::企業(yè)Web應用系統(tǒng)中實現(xiàn)跨瀏覽器Javascript調(diào)試的系統(tǒng)及其方法
技術領域:
:本發(fā)明涉及計算機軟件領域,特別涉及企業(yè)Web應用系統(tǒng)領域,具體是指一種企業(yè)Web應用系統(tǒng)中實現(xiàn)跨瀏覽器Javascript調(diào)試的系統(tǒng)及其方法。
背景技術:
:隨著現(xiàn)代社會科學技術的發(fā)展,大型企業(yè)的計算機軟件系統(tǒng)即企業(yè)應用系統(tǒng)的不斷進步,已經(jīng)由過去的C/S(客戶端/服務器)模式轉(zhuǎn)變?yōu)楝F(xiàn)在的B/S(瀏覽器/服務器)模式,傳統(tǒng)的企業(yè)應用系統(tǒng)已經(jīng)成為企業(yè)Web應用系統(tǒng)。Javascript語言是企業(yè)Web應用系統(tǒng)開發(fā)過程中一種必不可少的腳本語言,它提供了控制瀏覽器和在客戶端與用戶交互的方法,彌補了簡單HTML頁面的不足,增強了網(wǎng)頁與應用程序間的交互。Javascript可以說是Internet上最流行的腳本語言,它工作在包括IE、Firefox、Safari、0pera和GoogleChrome等主流瀏覽器中。隨著web2.0的發(fā)展,RIA(富Internet應用,RichInternetApplication)應用層出不窮,Javascript在其中擔任的角色越來越重要。另一方面,chrome等瀏覽器的發(fā)布,firefox和safari等瀏覽器不斷推出新版本,都給Javascript發(fā)展帶來了新的契機。程序調(diào)試目前主要存在兩種方式,一種是編譯調(diào)試目標文件,即將調(diào)試所用的語句編譯到目標代碼中,一種是調(diào)用該程序語言的運行容器接口丄/0++語言的調(diào)試采用的是前一種方式,例如目前比較流行的調(diào)試工具GDB和微軟的VisualStudio自帶的Debugger,在這種方式中首先需要編譯一個"debug"模式的程序并將調(diào)試語句編譯到程序中,同時在調(diào)試過程中debugger深層介入程序的運行,掌握和控制運行態(tài)的一些信息并將這些信息及時返回。Java調(diào)試采用的是后一種方式,即使用Java虛擬機工具接口(JavaVirtualMachineToolInterface,JVMTI)提供的調(diào)試接口。目前的Javascript調(diào)試工具也采用后一種方式,IE和Firefox分別提供了Javascript的調(diào)試接口,調(diào)試Javascript主要在IE和Firefox下進行。例如Firefox提供的調(diào)試接口是jsdIDebuggerService,通過向其中注入一些調(diào)試鉤子來實現(xiàn)調(diào)試。jsdIDebuggerService提供的調(diào)試接□主要有breakpointHook、debuggerHook、debugHook、errorHook、functionHook、interr卯tHook、scriptHook、throwHook、topLevelHook等。使用者只要實現(xiàn)這些接口并注冊到jsdIDebuggerService中,即可在Firefox中調(diào)試Javascript。Firebug、venkman、aptana、netbeans以及MyEclipse等者卩是使用這些接口在Firefox下實現(xiàn)Javascript調(diào)試。采用第二種調(diào)試方式的Javascript調(diào)試工具存在如下弊端首先不能跨瀏覽器,各個瀏覽器提供的調(diào)試接口都不相同,基于瀏覽器開發(fā)出來的調(diào)試工具無法通用,實現(xiàn)一個整合了多個瀏覽器引擎的調(diào)試工具本身也相當困難。其次需要安裝插件,此類調(diào)試工具都需要在瀏覽器上安裝插件。而且瀏覽器版本的升級會導致調(diào)試工具無法使用。
發(fā)明內(nèi)容本發(fā)明的目的是克服了上述現(xiàn)有技術中的缺點,提供一種不依賴于具體瀏覽器和調(diào)試插件的Javascript調(diào)試支持、系統(tǒng)架構(gòu)簡單、使用維護方便快捷、工作性能穩(wěn)定可靠、適用范圍較為廣泛的企業(yè)Web應用系統(tǒng)中實現(xiàn)跨瀏覽器Javascript調(diào)試的系統(tǒng)及其方法。為了實現(xiàn)上述的目的,本發(fā)明的企業(yè)Web應用系統(tǒng)中實現(xiàn)跨瀏覽器Javascript調(diào)試的系統(tǒng)及其方法如下該企業(yè)Web應用系統(tǒng)中實現(xiàn)跨瀏覽器Javascript調(diào)試的系統(tǒng),包括圖形化Javascript調(diào)試平臺和跨瀏覽器Javascript調(diào)試框架,其主要特點是,所述的圖形化Javascript調(diào)試平臺包括調(diào)試器引擎模塊,解析Javascript和Html,為編譯引擎模塊和調(diào)試器用戶界面模塊提供Javascript源代碼的調(diào)試信息,在斷點配置時及編譯引擎中被調(diào)用;Http服務器模塊,與瀏覽器、Web應用服務器以及本地文件系統(tǒng)進行通信;代理服務器模塊,提供訪問遠程Web應用服務器中URL的功能,統(tǒng)一URL域,支持跨域URL訪問;編譯引擎模塊,將調(diào)試源文件編譯為帶調(diào)試代碼的調(diào)試目標文件;調(diào)試服務器模塊,接受來自瀏覽器的調(diào)試代碼API的Ajax請求,解析調(diào)試代碼發(fā)送的指令、調(diào)用堆棧、變量等信息,并將斷點、指令等信息返回給瀏覽器端運行的調(diào)試代碼;調(diào)試器用戶界面模塊;提供與用戶交互的斷點管理、源文件定位、調(diào)試啟動、查看變量和調(diào)試動作功能,通過調(diào)試事件和調(diào)試服務器模塊交互;所述的跨瀏覽器的Javascript調(diào)試框架包括跨瀏覽器支持模塊,封裝有跨瀏覽器的Javascript應用程序接口;調(diào)試代碼應用程序接口模塊,提供調(diào)試函數(shù),在瀏覽器中運行的Javascript代碼在每一行代碼執(zhí)行之前,都會調(diào)用該調(diào)試函數(shù)來判斷程序是否進行中斷,如果遇到斷點或單步執(zhí)行等中斷時,就向調(diào)試服務器發(fā)送同步Ajax請求,將當前的資源、行號、調(diào)用堆棧和調(diào)試數(shù)據(jù)信息發(fā)送給調(diào)試服務器;調(diào)用堆棧管理模塊,提供客戶端調(diào)用堆棧管理功能,在跟進、跟出操作過程中進行堆棧判斷;調(diào)試命令解析模塊,用于與調(diào)試服務器模塊交互時解析調(diào)試服務器模塊傳回的調(diào)試指令。該企業(yè)Web應用系統(tǒng)中實現(xiàn)跨瀏覽器Javascript調(diào)試的系統(tǒng)中的調(diào)試信息包括總行數(shù)和可以下斷點的行號。該企業(yè)Web應用系統(tǒng)中實現(xiàn)跨瀏覽器Javascript調(diào)試的系統(tǒng)中的調(diào)試動作包括足艮出stepover、足艮進stepinto、返回stepreturn、繼續(xù)手丸行resume禾口終止terminate。該企業(yè)Web應用系統(tǒng)中實現(xiàn)跨瀏覽器Javascript調(diào)試的系統(tǒng)中的Javascript應用程序接口包括Ajax調(diào)用接口、json格式轉(zhuǎn)換和存儲調(diào)用堆棧接口。該企業(yè)Web應用系統(tǒng)中實現(xiàn)跨瀏覽器Javascript調(diào)試的系統(tǒng)中的調(diào)試指令包括足艮進stepInto、足艮出stepOver、返回stepReturn、繼續(xù)手丸行resume禾口終止terminate。該基于上述的系統(tǒng)實現(xiàn)企業(yè)Web應用系統(tǒng)中跨瀏覽器Javascript調(diào)試的方法,其主要特點是,所述的方法包括圖形化Javascript調(diào)試平臺的預處理操作、斷點配置操作和調(diào)試中斷操作,所述的圖形化Javascript調(diào)試平臺的預處理操作,包括以下步驟(11)所述的圖形化Javascript調(diào)試平臺進行初始化操作;(12)所述的調(diào)試器用戶界面模塊根據(jù)預先配置的調(diào)試端口啟動一個Http服務器模塊,并記錄調(diào)試服務器模塊的地址;(13)所述的圖形化Javascript調(diào)試平臺生成客戶端URL;(14)所述的圖形化Javascript調(diào)試平臺打開瀏覽器;(15)所述的瀏覽器向Http服務器模塊發(fā)送地址為該客戶端URL的HTTP請求;(16)所述的Http服務器模塊向用戶輸入的URL發(fā)送HTTP請求,獲得該URL上的調(diào)試源文件并保存;(17)所述的圖形化Javascript調(diào)試平臺將該Http服務器模塊所獲得的調(diào)試源文件的代碼文本顯示在調(diào)試器用戶界面模塊中;(18)所述的Http服務器模塊調(diào)用編譯引擎模塊生成編譯后的調(diào)試目標文件;(19)所述的編譯引擎模塊將編譯后的調(diào)試目標文件輸出到瀏覽器中執(zhí)行;所述的斷點配置操作,包括以下步驟(21)用戶通過調(diào)試器用戶界面模塊在調(diào)試源文件中設置斷點標記;(22)所述的調(diào)試器用戶界面模塊向跨瀏覽器Javascript調(diào)試框架中的斷點管理器添力口Javascript斷點標記;(23)所述的調(diào)試命令解析模塊每隔一系統(tǒng)預設的時間間隔周期性地向調(diào)試服務器模塊發(fā)送異步Ajax請求來獲取Javascript斷點信息;(24)所述的調(diào)試服務器模塊讀取該斷點管理器中所有的斷點信息;(25)所述的調(diào)試服務器模塊將獲得的所有斷點信息返回給所述的調(diào)試命令解析模塊;(26)所述的調(diào)試命令解析模塊將斷點信息保存到瀏覽器端;所述的調(diào)試中斷操作包括以下步驟(31)根據(jù)用戶的操作,所述的調(diào)試器用戶界面模塊將相應的調(diào)試指令發(fā)送到所述的調(diào)試服務器模塊;(32)所述的調(diào)試服務器模塊將該調(diào)試指令輸出到瀏覽器;(33)所述的調(diào)試命令解析模塊解析收到的該調(diào)試指令并執(zhí)行相應的操作;(34)瀏覽器執(zhí)行某一行Javascript代碼之前的調(diào)試代碼應用程序接口模塊中的調(diào)試函數(shù);(35)所述的調(diào)試代碼應用程序接口模塊根據(jù)指令信息判斷瀏覽器執(zhí)行的當前行是否需要中斷;(36)所述的調(diào)試代碼應用程序接口模塊發(fā)送同步Ajax請求給所述的調(diào)試服務器模塊;(37)所述的調(diào)試服務器模塊構(gòu)造數(shù)據(jù)模型并向所述的調(diào)試器用戶界面模塊發(fā)送調(diào)試事件;(38)所述的調(diào)試器用戶界面模塊向所述的調(diào)試服務器模塊請求數(shù)據(jù)模型并更新調(diào)試視(39)所述的調(diào)試服務器模塊掛起當前的同步Ajax請求,并把當前的請求對象和當前的堆棧關聯(lián)起來;(310)所述的調(diào)試器用戶界面模塊接收到調(diào)試事件和調(diào)試相關的資源、行號、調(diào)用堆棧、變量等數(shù)據(jù);(311)所述的調(diào)試器用戶界面模塊根據(jù)調(diào)試資源的相對路徑找到保存的調(diào)試源文件;(312)所述的調(diào)試器用戶界面模塊定位到調(diào)試源文件中的中斷行并顯示調(diào)試數(shù)據(jù)。該實現(xiàn)企業(yè)Web應用系統(tǒng)中跨瀏覽器Javascript調(diào)試的方法中的圖形化Javascript調(diào)試平臺進行初始化操作,包括以下步驟(111)根據(jù)用戶的操作,所述的圖形化Javascript調(diào)試平臺在所述的調(diào)試器用戶界面模塊中創(chuàng)建一個新的調(diào)試實例;(112)所述的圖形化Javascript調(diào)試平臺將用戶輸入的URL和瀏覽器路徑信息發(fā)送到啟動調(diào)試界面。該實現(xiàn)企業(yè)Web應用系統(tǒng)中跨瀏覽器Javascript調(diào)試的方法中的圖形化Javascript調(diào)試平臺生成客戶端URL,包括以下步驟(121)所述的圖形化Javascript調(diào)試平臺從所述的調(diào)試器用戶界面模塊中獲取調(diào)試服務器端口和用戶輸入的URL;(122)分別使用本地網(wǎng)絡地址127.0.0.1和調(diào)試服務器端口替換用戶輸入的URL中的服務器地址和端口,調(diào)試文件的文件名保持不變。該實現(xiàn)企業(yè)Web應用系統(tǒng)中跨瀏覽器Javascript調(diào)試的方法中的用戶輸入的URL格式為http:〃[服務器地址]:[端口]/[文件名]。該實現(xiàn)企業(yè)Web應用系統(tǒng)中跨瀏覽器Javascript調(diào)試的方法中的客戶端URL格式為http:〃127.0.0.1:[調(diào)試端口]/[文件名]。該實現(xiàn)企業(yè)Web應用系統(tǒng)中跨瀏覽器Javascript調(diào)試的方法中的Http服務器模塊調(diào)用編譯引擎模塊生成編譯后的調(diào)試目標文件,包括以下步驟(131)所述的Http服務器模塊傳入調(diào)試源文件的URL和文本內(nèi)容;(132)所述的Http服務器模塊調(diào)用編譯引擎編譯源文件資源;(133)所述的編譯引擎模塊根據(jù)對傳入資源的每一行判斷是否能下斷點,根據(jù)判斷結(jié)果分別執(zhí)行以下步驟(a)如果該行能下斷點,則在該行前面加上調(diào)試代碼;(b)如果該行不能下斷點,則前進到下一行;(134)所述的編譯引擎模塊將編譯完成后的代碼存為調(diào)試目標文件。該實現(xiàn)企業(yè)Web應用系統(tǒng)中跨瀏覽器Javascript調(diào)試的方法中的用戶通過調(diào)試器用戶界面模塊在調(diào)試源文件中設置斷點標記,包括以下步驟(211)所述的調(diào)試器用戶界面模塊傳入調(diào)試源文件的URL和文本內(nèi)容;(212)用戶在資源編輯器中添加Javascript斷點;(213)所述的調(diào)試器用戶界面模塊判斷當前行是否能下斷點,并根據(jù)判斷結(jié)果分別執(zhí)行以下步驟(a)如果當前行能下斷點,調(diào)試器UI往斷點管理器中添加一個斷點并通知調(diào)試視圖顯示斷點;(b)如果當前行不能下斷點,則用戶的操作無效。該實現(xiàn)企業(yè)Web應用系統(tǒng)中跨瀏覽器Javascript調(diào)試的方法中的系統(tǒng)預設的時間間隔為500ms。該實現(xiàn)企業(yè)Web應用系統(tǒng)中跨瀏覽器Javascript調(diào)試的方法中的調(diào)試命令解析模塊發(fā)送的異步Ajax請求數(shù)據(jù)的格式為[COMMAND]:[調(diào)試事件]。該實現(xiàn)企業(yè)Web應用系統(tǒng)中跨瀏覽器Javascript調(diào)試的方法中的調(diào)試服務器模塊返回給調(diào)試命令解析模塊的斷點信息數(shù)據(jù)的格式為[COMMAND]:[調(diào)試事件][斷點]:[[斷點1:[資源路徑][行號]][斷點2:[資源路徑][行號]]]。該實現(xiàn)企業(yè)Web應用系統(tǒng)中跨瀏覽器Javascript調(diào)試的方法中的調(diào)試指令包括足艮進stepInto、足艮出stepOver、返回stepReturn、繼續(xù)手丸行resume禾口終止terminate。該實現(xiàn)企業(yè)Web應用系統(tǒng)中跨瀏覽器Javascript調(diào)試的方法中的調(diào)試服務器模塊輸出到瀏覽器的指令格式為[COMMAND]:[調(diào)試指令]。該實現(xiàn)企業(yè)Web應用系統(tǒng)中跨瀏覽器Javascript調(diào)試的方法中的調(diào)試命令解析模塊解析收到的調(diào)試指令并執(zhí)行相應的操作,包括以下步驟(321)所述的調(diào)試命令解析模塊解析收到的調(diào)試指令;(322)所述的調(diào)試命令解析模塊根據(jù)調(diào)試指令來執(zhí)行相應的操作,具體包括以下步驟(a)如果收到的指令是終止terminate,則拋出一個終止terminate異常,終止程序執(zhí)行;(b)如果收到的指令是跟進st印Into、返回st印Return、繼續(xù)執(zhí)行resume或者跟出st印Over,則把當前指令狀態(tài)存放起來,下一句用戶的Javascript代碼執(zhí)行前的調(diào)試代碼應用程序接口模塊會根據(jù)當前指令和堆棧等信息判斷是否掛起;(c)如果不需要掛起,則繼續(xù)執(zhí)行用戶Javascript;(d)如果需要掛起,則進行下一個調(diào)試中斷操作。該實現(xiàn)企業(yè)Web應用系統(tǒng)中跨瀏覽器Javascript調(diào)試的方法中的調(diào)試代碼應用程序接口模塊根據(jù)指令信息判斷瀏覽器執(zhí)行的當前行是否需要中斷,包括以下步驟(331)所述的調(diào)試代碼應用程序接口模塊獲取當前的調(diào)試指令、斷點信息、以及當前的調(diào)用堆棧數(shù)據(jù);(332)調(diào)試代碼應用程序接口模塊判斷瀏覽器執(zhí)行的當前行是否需要中斷,并根據(jù)判斷結(jié)果分別執(zhí)行以下步驟(a)如果當前行不需要中斷,則繼續(xù)執(zhí)行;(b)如果當前行需要中斷,則調(diào)試代碼應用程序接口模塊調(diào)用調(diào)試堆棧管理獲得當前的堆棧以及當前的變量并傳送給調(diào)試服務器模塊。該實現(xiàn)企業(yè)Web應用系統(tǒng)中跨瀏覽器Javascript調(diào)試的方法中的調(diào)試服務器模塊構(gòu)造數(shù)據(jù)模型并向所述的調(diào)試器用戶界面模塊發(fā)送調(diào)試事件,包括以下步驟(341)所述的調(diào)試服務器模塊接收中斷請求;(342)所述的調(diào)試服務器模塊根據(jù)調(diào)試代碼應用程序接口模塊傳入的數(shù)據(jù)構(gòu)造調(diào)試數(shù)據(jù)模型;(343)所述的圖形化Javascript調(diào)試平臺向調(diào)試器用戶界面模塊發(fā)送調(diào)試事件。該實現(xiàn)企業(yè)Web應用系統(tǒng)中跨瀏覽器Javascript調(diào)試的方法中的調(diào)試器用戶界面模塊定位到調(diào)試源文件中的中斷行并顯示調(diào)試數(shù)據(jù),包括以下步驟(351)所述的調(diào)試器用戶界面模塊根據(jù)調(diào)試源文件路徑打開調(diào)試源文件并根據(jù)當前行號定位到中斷行;(352)所述的調(diào)試器用戶界面模塊根據(jù)調(diào)試數(shù)據(jù)模型顯示調(diào)試狀態(tài)及調(diào)試數(shù)據(jù)。該實現(xiàn)企業(yè)Web應用系統(tǒng)中跨瀏覽器Javascript調(diào)試的方法中的調(diào)試代碼應用程序接口模塊發(fā)送的同步Ajax請求數(shù)據(jù)格式為[COMMAND]:[調(diào)試事件][調(diào)用堆棧]:[調(diào)用堆棧和變量][資源路徑]:[資源文件URL][行號]:[當前Javascript行號]。該實現(xiàn)企業(yè)Web應用系統(tǒng)中跨瀏覽器Javascript調(diào)試的方法中的調(diào)試事件包括斷點breakpoint、足艮出stepOver、足艮進stepInto、返回stepRetrun、繼續(xù)手丸行resume、終止terminate。采用了該發(fā)明的企業(yè)Web應用系統(tǒng)中實現(xiàn)跨瀏覽器Javascript調(diào)試的系統(tǒng)及其方法,由于在圖形化調(diào)試平臺中對要進行調(diào)試的Html源文件或Javascript源文件進行了編譯,將調(diào)試代碼API添加到了源文件中可以設置斷點的代碼行前,生成了調(diào)試目標文件并在瀏覽器中執(zhí)行,當瀏覽器運行到Javascript代碼的斷點處時,調(diào)試代碼API根據(jù)圖形化調(diào)試平臺發(fā)送的調(diào)試指令判斷執(zhí)行中斷,將相關調(diào)試數(shù)據(jù)以同步Ajax請求的形式發(fā)送到圖形化調(diào)試平臺,最后調(diào)試平臺根據(jù)斷點信息進行斷點的展現(xiàn)操作,從而實現(xiàn)了跨瀏覽器的Javascript圖形化集成環(huán)境調(diào)試,增強了調(diào)試的直觀效果,提高了調(diào)試的效率,不僅操作簡單形象,而且快捷方便,整個調(diào)試環(huán)境的運行效率較高,系統(tǒng)性能穩(wěn)定可靠,降低了開發(fā)維護的成本;同時增強了系統(tǒng)可移植性和可擴展性;不僅如此,該方法還能夠快速回應業(yè)務需求的變化和技術變化,能夠支撐建立高度模塊化而且又高度整合的軟件系統(tǒng),不依賴于具體瀏覽器和調(diào)試插件的Javascript調(diào)試支持,系統(tǒng)架構(gòu)簡單,使用維護方便快捷,工作性能穩(wěn)定可靠,適用范圍較為廣泛,為企業(yè)Web應用軟件技術的進一步發(fā)展奠定了堅實的基礎。圖1為本發(fā)明的企業(yè)Web應用系統(tǒng)中實現(xiàn)跨瀏覽器Javascript調(diào)試的系統(tǒng)的整體架構(gòu)組成示意圖。圖2為本發(fā)明的企業(yè)Web應用系統(tǒng)中實現(xiàn)跨瀏覽器Javascript調(diào)試的系統(tǒng)在Eclipse調(diào)試框架中的啟動框架模型的類圖。圖3為本發(fā)明的企業(yè)Web應用系統(tǒng)中實現(xiàn)跨瀏覽器Javascript調(diào)試的系統(tǒng)在12Eclipse調(diào)試框架中的調(diào)試模塊模型的類圖。圖4為本發(fā)明的企業(yè)Web應用系統(tǒng)中實現(xiàn)跨瀏覽器Javascript調(diào)試的系統(tǒng)在Eclipse調(diào)試框架中的斷點模型的類圖。圖5為本發(fā)明的企業(yè)Web應用系統(tǒng)中實現(xiàn)跨瀏覽器Javascript調(diào)試的系統(tǒng)在Eclipse環(huán)境下JavascriptDebugToolkit(調(diào)試工具)調(diào)試界面的示意圖。圖6為本發(fā)明的實現(xiàn)企業(yè)Web應用系統(tǒng)中跨瀏覽器Javascript調(diào)試的方法的圖形化調(diào)試平臺的預處理操作的流程圖。圖7為本發(fā)明的實現(xiàn)企業(yè)Web應用系統(tǒng)中跨瀏覽器Javascript調(diào)試的方法的斷點配置操作的流程圖。圖8為本發(fā)明的實現(xiàn)企業(yè)Web應用系統(tǒng)中跨瀏覽器Javascript調(diào)試的方法的調(diào)試中斷操作的流程具體實施例方式為了能夠更清楚地理解本發(fā)明的技術內(nèi)容,特舉以下實施例詳細說明。請參閱圖1所示,該企業(yè)Web應用系統(tǒng)中實現(xiàn)跨瀏覽器Javascript調(diào)試的系統(tǒng),包括圖形化Javascript調(diào)試平臺和跨瀏覽器Javascript調(diào)試框架,其中,所述的圖形化Javascript調(diào)試平臺包括(1)調(diào)試器引擎模塊,解析Javascript和Html,為編譯引擎模塊和調(diào)試器用戶界面模塊提供Javascript源代碼的調(diào)試信息,在斷點配置時及編譯引擎中被調(diào)用;其中,該調(diào)試信息包括總行數(shù)和可以下斷點的行號;(2)Http服務器模塊,與瀏覽器、Web應用服務器以及本地文件系統(tǒng)進行通信;(3)代理服務器模塊,提供訪問遠程Web應用服務器中URL的功能,統(tǒng)一URL域,支持跨域URL訪問;(4)編譯引擎模塊,將調(diào)試源文件編譯為帶調(diào)試代碼的調(diào)試目標文件;(5)調(diào)試服務器模塊,接受來自瀏覽器的調(diào)試代碼API的Ajax請求,解析調(diào)試代碼發(fā)送的指令、調(diào)用堆棧、變量等信息,并將斷點、指令等信息返回給瀏覽器端運行的調(diào)試代碼;(6)調(diào)試器用戶界面模塊;提供與用戶交互的斷點管理、源文件定位、調(diào)試啟動、查看變量和調(diào)試動作功能,通過調(diào)試事件和調(diào)試服務器模塊交互;其中該調(diào)試動作包括跟出st印over、足艮進st印into、返回st印return、繼續(xù)執(zhí)行resume禾口終止terminate;所述的跨瀏覽器的Javascript調(diào)試框架包括(1)跨瀏覽器支持模塊,封裝有跨瀏覽器的Javascript應用程序接口;該Javascript應用程序接口包括Ajax調(diào)用接口、json格式轉(zhuǎn)換和存儲調(diào)用堆棧接口;(2)調(diào)試代碼應用程序接口模塊,提供調(diào)試函數(shù),在瀏覽器中運行的Javascript代碼在每一行代碼執(zhí)行之前,都會調(diào)用該調(diào)試函數(shù)來判斷程序是否進行中斷,如果遇到斷點或單步執(zhí)行等中斷時,就向調(diào)試服務器發(fā)送同步Ajax請求,將當前的資源、行號、調(diào)用堆棧和調(diào)試數(shù)據(jù)信息發(fā)送給調(diào)試服務器;(3)調(diào)用堆棧管理模塊,提供客戶端調(diào)用堆棧管理功能,在跟進、跟出操作過程中進行堆棧判斷;(4)調(diào)試命令解析模塊,用于與調(diào)試服務器模塊交互時解析調(diào)試服務器模塊傳回的調(diào)試指令;該調(diào)試指令包括跟進st印Into、跟出st印0ver、返回st印Return、繼續(xù)執(zhí)行resume禾口終止terminate。在實際使用當中,企業(yè)Web應用系統(tǒng)中實現(xiàn)跨瀏覽器Javascript調(diào)試的系統(tǒng)中包括圖形化Javascript調(diào)試平臺和跨瀏覽器Javascript調(diào)試框架,其中的圖形化Javascript調(diào)試平臺包括調(diào)試器引擎模塊、Http服務器模塊、代理服務器模塊、編譯引擎模塊、調(diào)試服務器模塊和調(diào)試器用戶界面(UI)模塊;跨瀏覽器的Javascript調(diào)試框架包括跨瀏覽器支持模塊、調(diào)試代碼應用程序接口(API)模塊、調(diào)用堆棧管理模塊以及調(diào)試命令解析模塊,具體如下參調(diào)試器引擎模塊——主要功能是解析Javascript和Html,為編譯引擎和調(diào)試器UI提供Javascript源代碼的調(diào)試信息,包括總行數(shù)、可以下斷點的行號等內(nèi)容,在斷點配置時及編譯引擎中被調(diào)用。參Http服務器模塊——提供了與瀏覽器、Web應用服務器以及本地文件系統(tǒng)通信的功能,基于Http服務器的圖形化Javascript調(diào)試平臺提供了代理服務器、編譯引擎和調(diào)試服務器三個功能模塊。參代理服務器模塊一一提供了訪問遠程Web應用服務器中URL的功能,代理服務器的主要作用是統(tǒng)一URL域,解決Javascript調(diào)試中的跨域問題。參編譯引擎模塊——提供了將調(diào)試源文件編譯為帶調(diào)試代碼的調(diào)試目標文件的引擎。參調(diào)試服務器模塊——接受來自瀏覽器的調(diào)試代碼API的Ajax請求,解析調(diào)試代碼發(fā)送的指令、調(diào)用堆棧、變量等信息,并將斷點、指令等信息返回給瀏覽器端運行的調(diào)試代碼。參調(diào)試器UI模塊——提供斷點管理、源文件定位、調(diào)試啟動、查看變量、調(diào)試動作(st印over、st印into、st印retr皿、resume、terminate)等與用戶交互的功會g,通過調(diào)試事件和調(diào)試服務器交互。參跨瀏覽器支持模塊——封裝了跨瀏覽器的JavascriptAPI,主要是Ajax調(diào)用、json格式轉(zhuǎn)換和存儲調(diào)用堆棧等方面的底層API,這些API是跨瀏覽器的,因此Javascript調(diào)試工具可以實現(xiàn)跨瀏覽器的Javascript調(diào)試。參調(diào)試代碼API模塊——提供了一個$jsd函數(shù),在瀏覽器中運行的Javascript代碼在每一行代碼執(zhí)行之前,都會調(diào)用該函數(shù)來判斷程序是否進行中斷;如果遇到斷點或單步執(zhí)行等中斷時,就向調(diào)試服務器發(fā)送同步Ajax請求,將當前的資源、行號、調(diào)用堆棧、調(diào)試數(shù)據(jù)等內(nèi)容發(fā)送給調(diào)試服務器。參調(diào)用堆棧管理模塊——提供了一個客戶端調(diào)用堆棧管理的功能,主要在跟進、跟出等操作過程中起堆棧判斷作用。參調(diào)試命令解析模塊——主要用于與調(diào)試服務器交互時解析調(diào)試服務器傳回的指令,包括執(zhí)行、跟進、跟出、下一步等。調(diào)試器UI需要實現(xiàn)Eclipse調(diào)試框架的幾個基本模塊(1)啟動框架(LaunchFramework)再請參閱圖2所示,其中表示LaunchFramework中的模型類圖,其中Launchconfigurationtypes-可用的Launch類型Launchconfigurations-Launch方式禾口內(nèi)容的描述參Launchmanager-負責存儲Launch類型,配置及Launch對象Launchdelegates-執(zhí)行LaunchLaunchobjects-Launchedprocess進禾呈/debugtargets目標的容器參Tabgroups——編輯Launch配置信息的UI界面(2)調(diào)試模塊(DebugModel)再請參閱圖3所示,其表示DebugModel的模型類圖,其中DebugModelElements-被調(diào)試的程序元素Capabilities-對st印ping、resuming、terminating的支持參DebugEvents——在執(zhí)行目標或進程時發(fā)生的事件參Views-顯示調(diào)試會話信息的視圖-threads、frames、variables等參Actions-與被調(diào)試程序之間交互動作的菜單-st印、resume等DebugModelPresentation-為debugmodelelements提供標簽禾口圖片(3)斷點(Breakpoint)再請參閱圖4所示,其表示斷點模型的類圖,斷點Breakpoint是在某位置或者滿足某種條件下掛起(suspend)程序的一種方式。斷點模型提供Add、Remove和Change斷點的通知機制,并提供跨工作臺調(diào)用斷點的持久化機制。其中參Breakpointextension-擴展斷點的擴展點參Breakpoint——代表斷點實例的模型對象參Marker——用于持久化斷點屬性以及在編輯器中顯示斷點參BreakpointManager——斷點倉庫,提供斷點變化的事件通知參DebugTarget——安裝斷點的底層運行而圖5為本發(fā)明的企業(yè)Web應用系統(tǒng)中實現(xiàn)跨瀏覽器Javascript調(diào)試的系統(tǒng)在Eclipse環(huán)境下JavascriptDebugToolkit(調(diào)試工具)調(diào)試界面的示意圖。再請參閱圖6至圖8所示,該基于上述的系統(tǒng)實現(xiàn)企業(yè)Web應用系統(tǒng)中跨瀏覽器Javascript調(diào)試的方法,其中包括圖形化Javascript調(diào)試平臺的預處理操作、斷點配置操作和調(diào)試中斷操作,所述的圖形化Javascript調(diào)試平臺的預處理操作,包括以下步驟(11)所述的圖形化Javascript調(diào)試平臺進行初始化操作,包括以下步驟(a)根據(jù)用戶的操作,所述的圖形化Javascript調(diào)試平臺在所述的調(diào)試器用戶界面模塊中創(chuàng)建一個新的調(diào)試實例;(b)所述的圖形化Javascript調(diào)試平臺將用戶輸入的URL和瀏覽器路徑信息發(fā)送到啟動調(diào)試界面;該用戶輸入的URL格式為http:〃[服務器地址]:[端口]/[文件名];(12)所述的調(diào)試器用戶界面模塊根據(jù)預先配置的調(diào)試端口啟動一個Http服務器模塊,并記錄調(diào)試服務器模塊的地址;(13)所述的圖形化Javascript調(diào)試平臺生成客戶端URL,包括以下步驟(a)所述的圖形化Javascript調(diào)試平臺從所述的調(diào)試器用戶界面模塊中獲取調(diào)試服務器端口和用戶輸入的URL;(b)分別使用本地網(wǎng)絡地址127.0.0.1和調(diào)試服務器端口替換用戶輸入的URL中的服務器地址和端口,調(diào)試文件的文件名保持不變;(14)所述的圖形化Javascript調(diào)試平臺打開瀏覽器;(15)所述的瀏覽器向Http服務器模塊發(fā)送地址為該客戶端URL的HTTP請求;該客戶端URL格式為http:〃127.0.0.1:[調(diào)試端口]/[文件名];(16)所述的Http服務器模塊向用戶輸入的URL發(fā)送HTTP請求,獲得該URL上的調(diào)試源文件并保存;(17)所述的圖形化Javascript調(diào)試平臺將該Http服務器模塊所獲得的調(diào)試源文件的代碼文本顯示在調(diào)試器用戶界面模塊中;(18)所述的Http服務器模塊調(diào)用編譯引擎模塊生成編譯后的調(diào)試目標文件,包括以下步驟(a)所述的Http服務器模塊傳入調(diào)試源文件的URL和文本內(nèi)容;(b)所述的Http服務器模塊調(diào)用編譯引擎編譯源文件資源;(c)所述的編譯引擎模塊根據(jù)對傳入資源的每一行判斷是否能下斷點,根據(jù)判斷結(jié)果分別執(zhí)行以下步驟(i)如果該行能下斷點,則在該行前面加上調(diào)試代碼;(ii)如果該行不能下斷點,則前進到下一行;(d)所述的編譯引擎模塊將編譯完成后的代碼存為調(diào)試目標文件;(19)所述的編譯引擎模塊將編譯后的調(diào)試目標文件輸出到瀏覽器中執(zhí)行;所述的斷點配置操作,包括以下步驟(21)用戶通過調(diào)試器用戶界面模塊在調(diào)試源文件中設置斷點標記,包括以下步驟(a)所述的調(diào)試器用戶界面模塊傳入調(diào)試源文件的URL和文本內(nèi)容;(b)用戶在資源編輯器中添加Javascript斷點;(c)所述的調(diào)試器用戶界面模塊判斷當前行是否能下斷點,并根據(jù)判斷結(jié)果分別執(zhí)行以下步驟(i)如果當前行能下斷點,調(diào)試器UI往斷點管理器中添加一個斷點并通知調(diào)試視圖顯示斷點;(ii)如果當前行不能下斷點,則用戶的操作無效;(22)所述的調(diào)試器用戶界面模塊向跨瀏覽器Javascript調(diào)試框架中的斷點管理器添力口Javascript斷點標記;(23)所述的調(diào)試命令解析模塊每隔一系統(tǒng)預設的時間間隔周期性地向調(diào)試服務器模塊發(fā)送異步Ajax請求來獲取Javascript斷點信息;該系統(tǒng)預設的時間間隔為500ms;該調(diào)試命令解析模塊發(fā)送的異步Ajax請求數(shù)據(jù)的格式為[COMMAND]:[調(diào)試事件];該調(diào)試事件包括斷點breakpoint、跟出st印0ver、跟進st印Into、返回st印Retr皿、繼續(xù)執(zhí)行resume、終止terminate;(24)所述的調(diào)試服務器模塊讀取該斷點管理器中所有的斷點信息;(25)所述的調(diào)試服務器模塊將獲得的所有斷點信息返回給所述的調(diào)試命令解析模塊;該調(diào)試服務器模塊返回給調(diào)試命令解析模塊的斷點信息數(shù)據(jù)的格式為[COMMAND]:[調(diào)試事件][斷點]:[[斷點1:[資源路徑][行號]][斷點2:[資源路徑][行號]]];(26)所述的調(diào)試命令解析模塊將斷點信息保存到瀏覽器端;所述的調(diào)試中斷操作包括以下步驟(31)根據(jù)用戶的操作,所述的調(diào)試器用戶界面模塊將相應的調(diào)試指令發(fā)送到所述的調(diào)試服務器模塊;該調(diào)試指令包括跟進st印Into、跟出st印Over、返回st印Return、繼續(xù)執(zhí)行resume禾口終止terminate;(32)所述的調(diào)試服務器模塊將該調(diào)試指令輸出到瀏覽器;該調(diào)試服務器模塊輸出到瀏覽器的指令格式為[COMMAND]:[調(diào)試指令];(33)所述的調(diào)試命令解析模塊解析收到的該調(diào)試指令并執(zhí)行相應的操作,包括以下步驟(a)所述的調(diào)試命令解析模塊解析收到的調(diào)試指令;(b)所述的調(diào)試命令解析模塊根據(jù)調(diào)試指令來執(zhí)行相應的操作,具體包括以下步驟(i)如果收到的指令是終止terminate,則拋出一個終止terminate異常,終止程序執(zhí)行;(ii)如果收到的指令是跟進st印Into、返回st印Return、繼續(xù)執(zhí)行resume或者跟出st印Over,則把當前指令狀態(tài)存放起來,下一句用戶的Javascript代碼執(zhí)行前的調(diào)試代碼應用程序接口模塊會根據(jù)當前指令和堆棧等信息判斷是否掛起;(iii)如果不需要掛起,則繼續(xù)執(zhí)行用戶Javascript;(iv)如果需要掛起,則進行下一個調(diào)試中斷操作;(34)瀏覽器執(zhí)行某一行Javascript代碼之前的調(diào)試代碼應用程序接口模塊中的調(diào)試函數(shù);(35)所述的調(diào)試代碼應用程序接口模塊根據(jù)指令信息判斷瀏覽器執(zhí)行的當前行是否需要中斷,包括以下步驟(a)所述的調(diào)試代碼應用程序接口模塊獲取當前的調(diào)試指令、斷點信息、以及當前的調(diào)用堆棧數(shù)據(jù);(b)調(diào)試代碼應用程序接口模塊判斷瀏覽器執(zhí)行的當前行是否需要中斷,并根據(jù)判斷結(jié)果分別執(zhí)行以下步驟(i)如果當前行不需要中斷,則繼續(xù)執(zhí)行;(ii)如果當前行需要中斷,則調(diào)試代碼應用程序接口模塊調(diào)用調(diào)試堆棧管理獲得當前的堆棧以及當前的變量并傳送給調(diào)試服務器模塊;(36)所述的調(diào)試代碼應用程序接口模塊發(fā)送同步Ajax請求給所述的調(diào)試服務器模塊;(37)所述的調(diào)試服務器模塊構(gòu)造數(shù)據(jù)模型并向所述的調(diào)試器用戶界面模塊發(fā)送調(diào)試事件,包括以下步驟17(a)所述的調(diào)試服務器模塊接收中斷請求;(b)所述的調(diào)試服務器模塊根據(jù)調(diào)試代碼應用程序接口模塊傳入的數(shù)據(jù)構(gòu)造調(diào)試數(shù)據(jù)模型;(c)所述的圖形化Javascript調(diào)試平臺向調(diào)試器用戶界面模塊發(fā)送調(diào)試事件;(38)所述的調(diào)試器用戶界面模塊向所述的調(diào)試服務器模塊請求數(shù)據(jù)模型并更新調(diào)試視圖;(39)所述的調(diào)試服務器模塊掛起當前的同步Ajax請求,并把當前的請求對象和當前的堆棧關聯(lián)起來;該同步Ajax請求數(shù)據(jù)格式為[COMMAND]:[調(diào)試事件][調(diào)用堆棧]:[調(diào)用堆棧和變量][資源路徑]:[資源文件URL][行號]:[當前Javascript行號];(310)所述的調(diào)試器用戶界面模塊接收到調(diào)試事件和調(diào)試相關的資源、行號、調(diào)用堆棧、變量等數(shù)據(jù);(311)所述的調(diào)試器用戶界面模塊根據(jù)調(diào)試資源的相對路徑找到保存的調(diào)試源文件;(312)所述的調(diào)試器用戶界面模塊定位到調(diào)試源文件中的中斷行并顯示調(diào)試數(shù)據(jù),包括以下步驟(a)所述的調(diào)試器用戶界面模塊根據(jù)調(diào)試源文件路徑打開調(diào)試源文件并根據(jù)當前行號定位到中斷行;(b)所述的調(diào)試器用戶界面模塊根據(jù)調(diào)試數(shù)據(jù)模型顯示調(diào)試狀態(tài)及調(diào)試數(shù)據(jù)。在實際使用當中,該企業(yè)Web應用系統(tǒng)中實現(xiàn)跨瀏覽器Javascript調(diào)試的方法,包括圖形化Javascript調(diào)試平臺的預處理操作、斷點配置操作和調(diào)試中斷操作,所述的圖形化Javascript調(diào)試平臺的預處理操作包括以下步驟(1)圖形化Javascript調(diào)試平臺的初始化操作,包括以下步驟(a)根據(jù)用戶的操作,圖形化Javascript調(diào)試平臺在調(diào)試器UI中創(chuàng)建一個新的調(diào)試實例;(b)圖形化Javascript調(diào)試平臺將用戶輸入的URL和瀏覽器路徑信息發(fā)送到啟動調(diào)試界面,所述的用戶輸入的URL格式為http:〃[服務器地址]:[端口]/[文件名];(2)調(diào)試器UI根據(jù)預先配置的調(diào)試端口啟動一個Http服務器,并記錄調(diào)試服務器地址;(3)圖形化Javascript調(diào)試平臺生成客戶端URL,包括以下步驟(a)圖形化Javascript調(diào)試平臺從調(diào)試器UI中獲取調(diào)試服務器端口和用戶輸入的亂;(b)分別使用本地網(wǎng)絡地址127.0.0.1和調(diào)試服務器端口替換用戶輸入URL中的服務器地址和端口,調(diào)試文件的文件名保持不變,所述的客戶端URL格式為http:〃127.0.0.1:[調(diào)試端口]/[文件名];(4)圖形化Javascript調(diào)試平臺打開瀏覽器;(5)瀏覽器向Http服務器發(fā)送地址為客戶端URL的HTTP請求;(6)Http服務器向用戶輸入的URL發(fā)送HTTP請求并獲得該URL上的調(diào)試源文件并保存;(7)圖形化Javascript調(diào)試平臺將Http服務器獲得的調(diào)試源文件的代碼文本顯示在調(diào)試器UI中;(8)Http服務器調(diào)用編譯引擎生成編譯后的調(diào)試目標文件,包括以下步驟(a)Http服務器傳入調(diào)試源文件的URL和文本內(nèi)容;(b)Http服務器調(diào)用編譯引擎編譯源文件資源;(c)編譯引擎根據(jù)對傳入資源的每一行判斷是否能下斷點,分別執(zhí)行以下步驟(i)如果該行能下斷點,則在該行前面加上調(diào)試代碼;(ii)如果該行不能下斷點,則前進到下一行;(d)編譯引擎將編譯完成后的代碼存為調(diào)試目標文件。(9)編譯引擎將編譯后的調(diào)試目標文件輸出到瀏覽器中執(zhí)行。所述的斷點配置操作包括以下步驟(1)用戶通過調(diào)試器UI在調(diào)試源文件中設置斷點標記,包括以下步驟(a)調(diào)試器UI傳入調(diào)試源文件的URL和文本內(nèi)容;(b)用戶在資源編輯器中添加Javascript斷點;(c)調(diào)試器UI判斷當前行是否能下斷點,分別執(zhí)行以下步驟(i)如果當前行能下斷點,調(diào)試器UI往斷點管理器中添加一個斷點并通知調(diào)試視圖顯示斷點;(ii)如果當前行不能下斷點,則用戶的操作無效;(2)調(diào)試器UI向跨瀏覽器Javascript調(diào)試框架中的斷點管理器添加Javascript斷點標記;(3)調(diào)試命令解析模塊定期向調(diào)試服務器發(fā)送異步Ajax請求來獲取Javascript斷點信息,所述的時間間隔為500ms;上述的調(diào)試命令解析模塊發(fā)送的異步Ajax請求數(shù)據(jù)的格式為[COMMAND]:[調(diào)試事件];(4)調(diào)試服務器讀取斷點管理器中所有的斷點信息;(5)調(diào)試服務器將獲得的所有斷點信息返回給調(diào)試命令解析模塊,所述的斷點信息數(shù)據(jù)的格式為[COMMAND]:[調(diào)試事件][斷點]:[[斷點1:[資源路徑][行號]][斷點2:[資源路徑][行號]]];(6)調(diào)試命令解析模塊將斷點信息保存到瀏覽器端。所述的調(diào)試中斷操作包括以下步驟(1)根據(jù)用戶的操作,調(diào)試器UI將相應的調(diào)試指令發(fā)送到調(diào)試服務器,所述的調(diào)試指令包括跟進(st印Into)、跟出(st印Over)、返回(st印Return)、繼續(xù)執(zhí)行(resume)、終止(terminate);(2)調(diào)試服務器將調(diào)試指令輸出到瀏覽器,所述的調(diào)試指令格式為[COMMAND]:[調(diào)試指令];(3)調(diào)試命令解析模塊解析收到的調(diào)試指令并執(zhí)行相應的操作,包括以下步驟(a)調(diào)試命令解析模塊解析收到的調(diào)試指令;(b)調(diào)試命令解析模塊根據(jù)指令來執(zhí)行相應的操作,分別包括以下步驟(i)如果收到的指令是terminate,則拋出一個terminate異常,終止程序執(zhí)行;(ii)如果收至lj的指令是st印Into、st印Return、resume、st印0ver等貝U把當前指令狀態(tài)存放起來,下一句用戶的Javascript代碼執(zhí)行前的調(diào)試代碼API會根據(jù)當前指令和堆棧等信息判斷是否掛起;(iii)如果不需要掛起則繼續(xù)執(zhí)行用戶Javascript;(iv)如果需要掛起則進行下一個調(diào)試中斷操作;(4)瀏覽器執(zhí)行某一行Javascript代碼之前的調(diào)試代碼API;(5)調(diào)試代碼API根據(jù)指令信息判斷瀏覽器執(zhí)行的當前行是否需要中斷,包括以下步驟(a)調(diào)試代碼API獲取當前的調(diào)試指令、斷點信息、以及當前的調(diào)用堆棧數(shù)據(jù);(b)調(diào)試代碼API判斷瀏覽器執(zhí)行的當前行是否需要中斷,分別執(zhí)行以下步驟(i)如果當前行不需要中斷,則繼續(xù)執(zhí)行;(ii)如果當前行需要中斷,則調(diào)試代碼API調(diào)用調(diào)試堆棧管理獲得當前的堆棧以及當前的變量并傳送給調(diào)試服務器;(6)調(diào)試代碼API發(fā)送同步Ajax請求給調(diào)試服務器,所述的同步Ajax請求數(shù)據(jù)格式為[COMMAND]:[調(diào)試事件][調(diào)用堆棧]:[調(diào)用堆棧和變量][資源路徑]:[資源文件URL][行號]:[當前Javascript行號];(7)調(diào)試服務器構(gòu)造數(shù)據(jù)模型并向調(diào)試器UI發(fā)送調(diào)試事件,所述的調(diào)試事件包括斷點(breakpoint)、足艮出(st印0ver)、足艮進(st印Into)、返回(st印Retrim)、繼續(xù)手丸行(resume)、終止(terminate);上述的構(gòu)造數(shù)據(jù)模型并向調(diào)試器UI發(fā)送調(diào)試事件的操作包括以下步驟(a)調(diào)試服務器接收中斷請求;(b)調(diào)試服務器根據(jù)調(diào)試代碼API傳入的數(shù)據(jù)構(gòu)造調(diào)試數(shù)據(jù)模型;(c)調(diào)試平臺向調(diào)試器UI發(fā)送調(diào)試事件;(8)調(diào)試器UI向調(diào)試服務器請求數(shù)據(jù)模型并更新調(diào)試視圖;(9)調(diào)試服務器掛起當前的同步Ajax請求,并把當前的請求對象和當前的堆棧關聯(lián)起來;(10)調(diào)試器UI接收到調(diào)試事件和調(diào)試相關的資源、行號、調(diào)用堆棧、變量等數(shù)據(jù);(11)調(diào)試器UI根據(jù)調(diào)試資源的相對路徑找到保存的調(diào)試源文件;(12)調(diào)試器UI定位到調(diào)試源文件中的中斷行并顯示調(diào)試數(shù)據(jù),包括以下步驟(a)調(diào)試器UI根據(jù)調(diào)試源文件路徑打開調(diào)試源文件并根據(jù)當前行號定位到中斷行;(b)調(diào)試器UI根據(jù)調(diào)試數(shù)據(jù)模型顯示調(diào)試狀態(tài)及調(diào)試數(shù)據(jù)。在實際應用中,本發(fā)明的跨瀏覽器Javascript調(diào)試的方法的具體過程如下1、添加斷點在Javascript調(diào)試平臺的實現(xiàn)中,添加斷點實際上就是為Javascript或Html調(diào)試源文件對應的IFile添力卩一個marker,并且設置了marker的屬性resource.createMarker(markerType);將斷點注冊到斷點管理器DebugPlugin.getDefault().getBreakpointManager().addBreakpoint(this)。Marker中記錄的信息有IFile的路徑、行號、斷點屬性等。在Javascript調(diào)試平臺添加斷點的過程中,需要先調(diào)用調(diào)試器引擎的API判斷該行是否能添加斷點。調(diào)試器引擎基于mozilla的開源框架rhino引擎,提供的核心API為IJsEngine:publicinterfaceIJsEngine{〃編譯javascriptpublicvoidcompilejs(Stringurl,Stringtext);publicvoidcompileHtml(Stringurl,Stringtext);publicbooleancanBreakLine(Stringurl,intline)5}具體過程如下(1)調(diào)試器UI判斷當前文件是Javascript調(diào)試源文件還是Html調(diào)試源文件;(2)如果是Javascript調(diào)試源文件,就調(diào)用compilejs方法,傳入調(diào)試源文件的URL和文本內(nèi)容;(3)如果是Html調(diào)試源文件,就調(diào)用compileHtml方法,傳入調(diào)試源文件的URL和文本內(nèi)容;(4)用戶在Html或Javascript編輯器中添加Javascript斷點;(5)調(diào)試器UI調(diào)用canBreakLine方法,傳入調(diào)試源文件的URL和當前的行號,判斷當前行是否能下斷點;(6)如果當前行能下斷點,調(diào)試器UI調(diào)用Eclipse的斷點管理器BreakPointManager的addBreakPoint方法,添力口一個斷點;(7)Eclipse的斷點管理器BreakPointManager通知Eclipse的各個視圖顯示斷點;(8)如果當前行不能下斷點,則用戶的操作無效;2、刪除斷點刪除斷點實際上就是刪除Javascript或Html調(diào)試源文件對應的IFile上對應的IMarker,resource.removeMarker(markerType);在斷點管理器中注銷斷點DebugPlugin.getDefault().getBreakpointManager().removeBreakpoint(this)。3、將Html或Javascript調(diào)試源文件編譯為調(diào)試目標文件(1)判斷源文件是Html調(diào)試源文件還是Javascript調(diào)試源文件;(2)如果是Javascript調(diào)試源文件則直接調(diào)用rhino引擎的(newDim())sourcelnfo(url)方法解析Javascript。如果是Html調(diào)試源文件則先解析html文件,只留下〈script〉標簽中的Javascript內(nèi)容,再調(diào)用rhino引擎的(newDim()).sourcelnfo(url)方法角牟析Javascript;(3)Rhino引擎解析Javascript后把源代碼信息存在Sourcelnfo類中,Sourcelnfo類提供了breakableLines屬性用于記錄哪些行可以下斷點;(4)編譯引擎遍歷源代碼的行,根據(jù)Sourcelnfo的breakablesLines判斷該行是否能夠下斷點,如果能夠下斷點則在該行前面添加調(diào)試代碼,調(diào)試代碼包含當前的源文件路徑、行號、當前上下文等內(nèi)容,調(diào)試代碼的示例為$jsd(〃test.js〃,l,...);編譯引擎編譯前后的Javascript代碼調(diào)試源代碼f皿ctiontest(a,b){rare=a+b;returnc^調(diào)試目標代碼$jsd(〃test,js〃,1,…);functiontest(a,b){$jsd(〃test,js〃,3,…);varc=a+b;$jsd(〃test,js〃,5,…);returnc;$jsdrtest.js〃,6,);}編譯引擎編譯前后的Html代碼〈html〉〈head〉調(diào)試源〈script〉testOj〈/script〉代碼〈/head〉〈body〉〈/body〉〈/html〉〈scriptsrc=,,jsdebug.js,,〉〈/script〉〈html〉〈head〉調(diào)試目〈script〉$jsd(〃test,js〃,4,…);test();標代碼〈/script〉〈/head〉〈body〉〈/body〉〈/html〉224、在進行Javascript調(diào)試過程中定位Javascript斷點由于在編譯引擎將Html和Javascript調(diào)試源文件編譯為調(diào)試目標文件時已經(jīng)將文件路徑和行號添加到了每行可以下斷點的Javascript代碼前,因此不需要額外的操作來查找相關信息;當執(zhí)行到斷點時,調(diào)試代碼API根據(jù)當前代碼情況調(diào)用調(diào)試堆棧管理獲得當前的堆棧信息,并發(fā)送同步Ajax請求給調(diào)試服務器。調(diào)試代碼API發(fā)送的數(shù)據(jù)如下{〃STACK":{window:{document:{body:{tagName:,,BODY"}}},a:undefined},〃COMMAND":〃BREAKPOINT",〃RESOURCE":〃/jsdebug/jsdt_sO.5/test/test.js〃,〃LINE":2}5、調(diào)試中的中斷判斷調(diào)試目標文件的調(diào)試代碼在Javascript代碼的每一行代碼之前,因此在執(zhí)行每一行代碼前都會先調(diào)用調(diào)試代碼,調(diào)試代碼調(diào)用了調(diào)試代碼API。調(diào)試代碼API首先判斷當前行是否有斷點,如果有斷點則執(zhí)行中斷操作,如果沒有斷點則根據(jù)當前用戶的調(diào)試指令(resume、setplnto、st印0ver、st印Return、terminate)做下一步判斷(1)如果用戶的調(diào)試指令是resume,則跳出調(diào)試代碼,執(zhí)行用戶的javascript代碼;(2)如果用戶的調(diào)試指令是st印Into,則調(diào)試代碼API會調(diào)用當前的調(diào)用堆棧管理的API判斷當前的堆棧和上一個堆棧是否是同一個,如果是同一個堆棧,則跳出調(diào)試代碼,繼續(xù)執(zhí)行用戶的Javascript代碼,如果不是同一個堆棧,則執(zhí)行中斷操作;(3)如果用戶的調(diào)試指令是setpOver則執(zhí)行中斷操作;(4)如果用戶的調(diào)試指令是setpReturn,則調(diào)試代碼API會調(diào)用當前的調(diào)用堆棧管理的API判斷當前的堆棧和上上一個堆棧是否是同一個,如果是同一個,則執(zhí)行中斷操作,否則跳出調(diào)試代碼,繼續(xù)執(zhí)行用戶的Javascript代碼;(5)如果用戶的調(diào)試指令是terminate,則拋出一個terminate的異常,結(jié)束調(diào)試;調(diào)試中斷是指中斷當前執(zhí)行的Javascript代碼行,并在調(diào)試平臺的UI上顯示當前調(diào)試的行,采用的是同步的Ajax請求技術來向調(diào)試服務器發(fā)送Ajax請求(1)調(diào)試代碼API通過調(diào)用堆棧管理的API獲得當前的調(diào)用堆棧和用戶定義變量的信息。調(diào)用堆棧管理的API通過arguments,callee.caller獲得當前的調(diào)用堆棧。調(diào)用堆棧管理通過解析arguments,callee.caller函數(shù)的源代碼獲得用戶定義的變量,通過eval函數(shù)獲得這些變量的值;(2)調(diào)試代碼API將調(diào)用堆棧、上下文變量、源文件路徑、當前行號等信息組合為json格式的數(shù)據(jù)發(fā)送給調(diào)試服務器;(3)調(diào)試服務器接收到Ajax請求,根據(jù)調(diào)試代碼API傳入的數(shù)據(jù)構(gòu)造調(diào)試器UI所需要的數(shù)據(jù)模型,然后事件處理器向調(diào)試器UI發(fā)送調(diào)試事件。調(diào)試器UI會根據(jù)調(diào)試數(shù)據(jù)模型更新調(diào)試視圖。本發(fā)明的Web應用系統(tǒng)中實現(xiàn)跨瀏覽器Javascript調(diào)試的方法有以下優(yōu)點1、跨瀏覽器下表是JavascriptDebugToolkit和其他主流調(diào)試工具對瀏覽器的支持情況對比<table>tableseeoriginaldocumentpage24</column></row><table>2、無插件目前其他調(diào)試工具都需要在瀏覽器中安裝插件,譬如Firebug和Venkman都是firefox上的插件,NetBeans也需要在Firefox禾PIE上安裝插件,而JavascriptDebugToolkit不需要安裝瀏覽器插件。3、不需要隨著瀏覽器的版本而升級隨著瀏覽器版本的升級,很多工具都無法支持新的版本,譬如Firefox2升能到Firefox3版本的時候,F(xiàn)irebug、Aptana等工具都不能正常使用,而使用JavascriptDebugToolkit卻不需要關心瀏覽器的版本。采用了上述的企業(yè)Web應用系統(tǒng)中實現(xiàn)跨瀏覽器Javascript調(diào)試的系統(tǒng)及其方法,由于在圖形化調(diào)試平臺中對要進行調(diào)試的Html源文件或Javascript源文件進行了編譯,將調(diào)試代碼API添加到了源文件中可以設置斷點的代碼行前,生成了調(diào)試目標文件并在瀏覽器中執(zhí)行,當瀏覽器運行到Javascript代碼的斷點處時,調(diào)試代碼API根據(jù)圖形化調(diào)試平臺發(fā)送的調(diào)試指令判斷執(zhí)行中斷,將相關調(diào)試數(shù)據(jù)以同步Ajax請求的形式發(fā)送到圖形化調(diào)試平臺,最后調(diào)試平臺根據(jù)斷點信息進行斷點的展現(xiàn)操作,從而實現(xiàn)了跨瀏覽器的Javascript圖形化集成環(huán)境調(diào)試,增強了調(diào)試的直觀效果,提高了調(diào)試的效率,不僅操作簡單形象,而且快捷方便,整個調(diào)試環(huán)境的運行效率較高,系統(tǒng)性能穩(wěn)定可靠,降低了開發(fā)維護的成本;同時增強了系統(tǒng)可移植性和可擴展性;不僅如此,該方法還能夠快速回應業(yè)務需求的變化和技術變化,能夠支撐建立高度模塊化而且又高度整合的軟件系統(tǒng),不依賴于具體瀏覽器和調(diào)試插件的Javascript調(diào)試支持,系統(tǒng)架構(gòu)簡單,使用維護方便快捷,工作性能穩(wěn)定可靠,適用范圍較為廣泛,為企業(yè)Web應用軟件技術的進一步發(fā)展奠定了堅實的基礎。在此說明書中,本發(fā)明已參照其特定的實施例作了描述。但是,很顯然仍可以作出各種修改和變換而不背離本發(fā)明的精神和范圍。因此,說明書和附圖應被認為是說明性的而非限制性的。權利要求一種企業(yè)Web應用系統(tǒng)中實現(xiàn)跨瀏覽器Javascript調(diào)試的系統(tǒng),包括圖形化Javascript調(diào)試平臺和跨瀏覽器Javascript調(diào)試框架,其特征在于,所述的圖形化Javascript調(diào)試平臺包括調(diào)試器引擎模塊,解析Javascript和Html,為編譯引擎模塊和調(diào)試器用戶界面模塊提供Javascript源代碼的調(diào)試信息,在斷點配置時及編譯引擎中被調(diào)用;Http服務器模塊,與瀏覽器、Web應用服務器以及本地文件系統(tǒng)進行通信;代理服務器模塊,提供訪問遠程Web應用服務器中URL的功能,統(tǒng)一URL域,支持跨域URL訪問;編譯引擎模塊,將調(diào)試源文件編譯為帶調(diào)試代碼的調(diào)試目標文件;調(diào)試服務器模塊,接受來自瀏覽器的調(diào)試代碼API的Ajax請求,解析調(diào)試代碼發(fā)送的指令、調(diào)用堆棧、變量等信息,并將斷點、指令等信息返回給瀏覽器端運行的調(diào)試代碼;調(diào)試器用戶界面模塊;提供與用戶交互的斷點管理、源文件定位、調(diào)試啟動、查看變量和調(diào)試動作功能,通過調(diào)試事件和調(diào)試服務器模塊交互;所述的跨瀏覽器的Javascript調(diào)試框架包括跨瀏覽器支持模塊,封裝有跨瀏覽器的Javascript應用程序接口;調(diào)試代碼應用程序接口模塊,提供調(diào)試函數(shù),在瀏覽器中運行的Javascript代碼在每一行代碼執(zhí)行之前,都會調(diào)用該調(diào)試函數(shù)來判斷程序是否進行中斷,如果遇到斷點或單步執(zhí)行等中斷時,就向調(diào)試服務器發(fā)送同步Ajax請求,將當前的資源、行號、調(diào)用堆棧和調(diào)試數(shù)據(jù)信息發(fā)送給調(diào)試服務器;調(diào)用堆棧管理模塊,提供客戶端調(diào)用堆棧管理功能,在跟進、跟出操作過程中進行堆棧判斷;調(diào)試命令解析模塊,用于與調(diào)試服務器模塊交互時解析調(diào)試服務器模塊傳回的調(diào)試指令。2.根據(jù)權利要求l所述的企業(yè)Web應用系統(tǒng)中實現(xiàn)跨瀏覽器Javascript調(diào)試的系統(tǒng),其特征在于,所述的調(diào)試信息包括總行數(shù)和可以下斷點的行號。3.根據(jù)權利要求l所述的企業(yè)Web應用系統(tǒng)中實現(xiàn)跨瀏覽器Javascript調(diào)試的系統(tǒng),其特征在于,所述的調(diào)試動作包括跟出st印over、跟進st印into、返回st印return、繼續(xù)執(zhí)行resume禾口終止terminate。4.根據(jù)權利要求1所述的企業(yè)Web應用系統(tǒng)中實現(xiàn)跨瀏覽器Javascript調(diào)試的系統(tǒng),其特征在于,所述的Javascript應用程序接口包括Ajax調(diào)用接口、json格式轉(zhuǎn)換和存儲調(diào)用堆棧接口。5.根據(jù)權利要求1所述的企業(yè)Web應用系統(tǒng)中實現(xiàn)跨瀏覽器Javascript調(diào)試的系統(tǒng),其特征在于,所述的調(diào)試指令包括跟進st印Into、跟出st印0ver、返回st印Return、繼續(xù)執(zhí)行resume禾口終止terminate。6.—種基于權利要求1所述的系統(tǒng)實現(xiàn)企業(yè)Web應用系統(tǒng)中跨瀏覽器Javascript調(diào)試的方法,其特征在于,所述的方法包括圖形化Javascript調(diào)試平臺的預處理操作、斷點配置操作和調(diào)試中斷操作,所述的圖形化Javascript調(diào)試平臺的預處理操作,包括以下步驟(11)所述的圖形化Javascript調(diào)試平臺進行初始化操作;(12)所述的調(diào)試器用戶界面模塊根據(jù)預先配置的調(diào)試端口啟動一個Http服務器模塊,并記錄調(diào)試服務器模塊的地址;(13)所述的圖形化Javascript調(diào)試平臺生成客戶端URL;(14)所述的圖形化Javascript調(diào)試平臺打開瀏覽器;(15)所述的瀏覽器向Http服務器模塊發(fā)送地址為該客戶端URL的HTTP請求;(16)所述的Http服務器模塊向用戶輸入的URL發(fā)送HTTP請求,獲得該URL上的調(diào)試源文件并保存;(17)所述的圖形化Javascript調(diào)試平臺將該Http服務器模塊所獲得的調(diào)試源文件的代碼文本顯示在調(diào)試器用戶界面模塊中;(18)所述的Http服務器模塊調(diào)用編譯引擎模塊生成編譯后的調(diào)試目標文件;(19)所述的編譯引擎模塊將編譯后的調(diào)試目標文件輸出到瀏覽器中執(zhí)行;所述的斷點配置操作,包括以下步驟(21)用戶通過調(diào)試器用戶界面模塊在調(diào)試源文件中設置斷點標記;(22)所述的調(diào)試器用戶界面模塊向跨瀏覽器Javascript調(diào)試框架中的斷點管理器添力口Javascript斷點標記;(23)所述的調(diào)試命令解析模塊每隔一系統(tǒng)預設的時間間隔周期性地向調(diào)試服務器模塊發(fā)送異步Ajax請求來獲取Javascript斷點信息;(24)所述的調(diào)試服務器模塊讀取該斷點管理器中所有的斷點信息;(25)所述的調(diào)試服務器模塊將獲得的所有斷點信息返回給所述的調(diào)試命令解析模塊;(26)所述的調(diào)試命令解析模塊將斷點信息保存到瀏覽器端;所述的調(diào)試中斷操作包括以下步驟(31)根據(jù)用戶的操作,所述的調(diào)試器用戶界面模塊將相應的調(diào)試指令發(fā)送到所述的調(diào)試服務器模塊;(32)所述的調(diào)試服務器模塊將該調(diào)試指令輸出到瀏覽器;(33)所述的調(diào)試命令解析模塊解析收到的該調(diào)試指令并執(zhí)行相應的操作;(34)瀏覽器執(zhí)行某一行Javascript代碼之前的調(diào)試代碼應用程序接口模塊中的調(diào)試函數(shù);(35)所述的調(diào)試代碼應用程序接口模塊根據(jù)指令信息判斷瀏覽器執(zhí)行的當前行是否需要中斷;(36)所述的調(diào)試代碼應用程序接口模塊發(fā)送同步Ajax請求給所述的調(diào)試服務器模塊;(37)所述的調(diào)試服務器模塊構(gòu)造數(shù)據(jù)模型并向所述的調(diào)試器用戶界面模塊發(fā)送調(diào)試事件;(38)所述的調(diào)試器用戶界面模塊向所述的調(diào)試服務器模塊請求數(shù)據(jù)模型并更新調(diào)試視圖;(39)所述的調(diào)試服務器模塊掛起當前的同步Ajax請求,并把當前的請求對象和當前的堆棧關聯(lián)起來;(310)所述的調(diào)試器用戶界面模塊接收到調(diào)試事件和調(diào)試相關的資源、行號、調(diào)用堆棧、變量等數(shù)據(jù);(311)所述的調(diào)試器用戶界面模塊根據(jù)調(diào)試資源的相對路徑找到保存的調(diào)試源文件;(312)所述的調(diào)試器用戶界面模塊定位到調(diào)試源文件中的中斷行并顯示調(diào)試數(shù)據(jù)。7.根據(jù)權利要求6所述的實現(xiàn)企業(yè)Web應用系統(tǒng)中跨瀏覽器Javascript調(diào)試的方法,其特征在于,所述的圖形化Javascript調(diào)試平臺進行初始化操作,包括以下步驟(111)根據(jù)用戶的操作,所述的圖形化Javascript調(diào)試平臺在所述的調(diào)試器用戶界面模塊中創(chuàng)建一個新的調(diào)試實例;(112)所述的圖形化Javascript調(diào)試平臺將用戶輸入的URL和瀏覽器路徑信息發(fā)送到啟動調(diào)試界面。8.根據(jù)權利要求7所述的實現(xiàn)企業(yè)Web應用系統(tǒng)中跨瀏覽器Javascript調(diào)試的方法,其特征在于,所述的圖形化Javascript調(diào)試平臺生成客戶端URL,包括以下步驟(121)所述的圖形化Javascript調(diào)試平臺從所述的調(diào)試器用戶界面模塊中獲取調(diào)試服務器端口和用戶輸入的URL;(122)分別使用本地網(wǎng)絡地址127.0.0.1和調(diào)試服務器端口替換用戶輸入的URL中的服務器地址和端口,調(diào)試文件的文件名保持不變。9.根據(jù)權利要求8所述的實現(xiàn)企業(yè)Web應用系統(tǒng)中跨瀏覽器Javascript調(diào)試的方法,其特征在于,所述的用戶輸入的URL格式為http:〃[服務器地址]:[端口]/[文件名]。10.根據(jù)權利要求8所述的實現(xiàn)企業(yè)Web應用系統(tǒng)中跨瀏覽器Javascript調(diào)試的方法,其特征在于,所述的客戶端URL格式為http:〃127.0.0.1:[調(diào)試端口]/[文件名]。11.根據(jù)權利要求6至10中任一項所述的實現(xiàn)企業(yè)Web應用系統(tǒng)中跨瀏覽器Javascript調(diào)試的方法,其特征在于,所述的Http服務器模塊調(diào)用編譯引擎模塊生成編譯后的調(diào)試目標文件,包括以下步驟(131)所述的Http服務器模塊傳入調(diào)試源文件的URL和文本內(nèi)容;(132)所述的Http服務器模塊調(diào)用編譯引擎編譯源文件資源;(133)所述的編譯引擎模塊根據(jù)對傳入資源的每一行判斷是否能下斷點,根據(jù)判斷結(jié)果分別執(zhí)行以下步驟(a)如果該行能下斷點,則在該行前面加上調(diào)試代碼;(b)如果該行不能下斷點,則前進到下一行;(134)所述的編譯引擎模塊將編譯完成后的代碼存為調(diào)試目標文件。12.根據(jù)權利要求11所述的實現(xiàn)企業(yè)Web應用系統(tǒng)中跨瀏覽器Javascript調(diào)試的方法,其特征在于,所述的用戶通過調(diào)試器用戶界面模塊在調(diào)試源文件中設置斷點標記,包括以下步驟(211)所述的調(diào)試器用戶界面模塊傳入調(diào)試源文件的URL和文本內(nèi)容;(212)用戶在資源編輯器中添加Javascript斷點;(213)所述的調(diào)試器用戶界面模塊判斷當前行是否能下斷點,并根據(jù)判斷結(jié)果分別執(zhí)行以下步驟(a)如果當前行能下斷點,調(diào)試器UI往斷點管理器中添加一個斷點并通知調(diào)試視圖顯示斷點;(b)如果當前行不能下斷點,則用戶的操作無效。13.根據(jù)權利要求6至10中任一項所述的實現(xiàn)企業(yè)Web應用系統(tǒng)中跨瀏覽器Javascript調(diào)試的方法,其特征在于,所述的系統(tǒng)預設的時間間隔為500ms。14.根據(jù)權利要求6至10中任一項所述的實現(xiàn)企業(yè)Web應用系統(tǒng)中跨瀏覽器Javascript調(diào)試的方法,其特征在于,所述的調(diào)試命令解析模塊發(fā)送的異步Ajax請求數(shù)據(jù)的格式為[COMMAND]:[調(diào)試事件]。15.根據(jù)權利要求6至10中任一項所述的實現(xiàn)企業(yè)Web應用系統(tǒng)中跨瀏覽器Javascript調(diào)試的方法,其特征在于,所述的調(diào)試服務器模塊返回給調(diào)試命令解析模塊的斷點信息數(shù)據(jù)的格式為[COMMAND]:[調(diào)試事件][斷點]:[[斷點1:[資源路徑][行號]][斷點2:[資源路徑][行號]]]。16.根據(jù)權利要求6至10中任一項所述的實現(xiàn)企業(yè)Web應用系統(tǒng)中跨瀏覽器Javascript調(diào)試的方法,其特征在于,所述的調(diào)試指令包括跟進st印Into、跟出st印Over、返回st印Return、繼續(xù)執(zhí)行resume禾口終止terminate。17.根據(jù)權利要求6至10中任一項所述的實現(xiàn)企業(yè)Web應用系統(tǒng)中跨瀏覽器Javascript調(diào)試的方法,其特征在于,所述的調(diào)試服務器模塊輸出到瀏覽器的指令格式為[COMMAND]:[調(diào)試指令]。18.根據(jù)權利要求16所述的實現(xiàn)企業(yè)Web應用系統(tǒng)中跨瀏覽器Javascript調(diào)試的方法,其特征在于,所述的調(diào)試命令解析模塊解析收到的調(diào)試指令并執(zhí)行相應的操作,包括以下步驟(321)所述的調(diào)試命令解析模塊解析收到的調(diào)試指令;(322)所述的調(diào)試命令解析模塊根據(jù)調(diào)試指令來執(zhí)行相應的操作,具體包括以下步驟(a)如果收到的指令是終止terminate,則拋出一個終止terminate異常,終止程序執(zhí)行;(b)如果收到的指令是跟進st印Into、返回st印Return、繼續(xù)執(zhí)行resume或者跟出st印0ver,則把當前指令狀態(tài)存放起來,下一句用戶的Javascript代碼執(zhí)行前的調(diào)試代碼應用程序接口模塊會根據(jù)當前指令和堆棧等信息判斷是否掛起;(c)如果不需要掛起,則繼續(xù)執(zhí)行用戶Javascript;(d)如果需要掛起,則進行下一個調(diào)試中斷操作。19.根據(jù)權利要求18所述的實現(xiàn)企業(yè)Web應用系統(tǒng)中跨瀏覽器Javascript調(diào)試的方法,其特征在于,所述的調(diào)試代碼應用程序接口模塊根據(jù)指令信息判斷瀏覽器執(zhí)行的當前行是否需要中斷,包括以下步驟(331)所述的調(diào)試代碼應用程序接口模塊獲取當前的調(diào)試指令、斷點信息、以及當前的調(diào)用堆棧數(shù)據(jù);(332)調(diào)試代碼應用程序接口模塊判斷瀏覽器執(zhí)行的當前行是否需要中斷,并根據(jù)判斷結(jié)果分別執(zhí)行以下步驟(a)如果當前行不需要中斷,則繼續(xù)執(zhí)行;(b)如果當前行需要中斷,則調(diào)試代碼應用程序接口模塊調(diào)用調(diào)試堆棧管理獲得當前的堆棧以及當前的變量并傳送給調(diào)試服務器模塊。20.根據(jù)權利要求19所述的實現(xiàn)企業(yè)Web應用系統(tǒng)中跨瀏覽器Javascript調(diào)試的方法,其特征在于,所述的調(diào)試服務器模塊構(gòu)造數(shù)據(jù)模型并向所述的調(diào)試器用戶界面模塊發(fā)送調(diào)試事件,包括以下步驟(341)所述的調(diào)試服務器模塊接收中斷請求;(342)所述的調(diào)試服務器模塊根據(jù)調(diào)試代碼應用程序接口模塊傳入的數(shù)據(jù)構(gòu)造調(diào)試數(shù)據(jù)模型;(343)所述的圖形化Javascript調(diào)試平臺向調(diào)試器用戶界面模塊發(fā)送調(diào)試事件。21.根據(jù)權利要求20所述的實現(xiàn)企業(yè)Web應用系統(tǒng)中跨瀏覽器Javascript調(diào)試的方法,其特征在于,所述的調(diào)試器用戶界面模塊定位到調(diào)試源文件中的中斷行并顯示調(diào)試數(shù)據(jù),包括以下步驟(351)所述的調(diào)試器用戶界面模塊根據(jù)調(diào)試源文件路徑打開調(diào)試源文件并根據(jù)當前行號定位到中斷行;(352)所述的調(diào)試器用戶界面模塊根據(jù)調(diào)試數(shù)據(jù)模型顯示調(diào)試狀態(tài)及調(diào)試數(shù)據(jù)。22.根據(jù)權利要求6至10中任一項所述的實現(xiàn)企業(yè)Web應用系統(tǒng)中跨瀏覽器Javascript調(diào)試的方法,其特征在于,所述的調(diào)試代碼應用程序接口模塊發(fā)送的同步Ajax請求數(shù)據(jù)格式為[COMMAND]:[調(diào)試事件][調(diào)用堆棧]:[調(diào)用堆棧和變量][資源路徑]:[資源文件URL][行號]:[當前Javascript行號]。23.根據(jù)權利要求6至10中任一項所述的實現(xiàn)企業(yè)Web應用系統(tǒng)中跨瀏覽器Javascript調(diào)試的方法,其特征在于,所述的調(diào)試事件包括斷點breakpoint跟出st印0ver、足艮進st印Into、返回st印Retrun、繼續(xù)手丸行resume、終止terminate。全文摘要本發(fā)明涉及一種企業(yè)Web應用系統(tǒng)中實現(xiàn)跨瀏覽器Javascript調(diào)試的系統(tǒng),包括圖形化Javascript調(diào)試平臺和跨瀏覽器Javascript調(diào)試框架,其中圖形化Javascript調(diào)試平臺包括調(diào)試器引擎模塊、Http服務器模塊、代理服務器模塊、編譯引擎模塊、調(diào)試服務器模塊和調(diào)試器UI模塊,跨瀏覽器的Javascript調(diào)試框架包括跨瀏覽器支持模塊、調(diào)試代碼API模塊、調(diào)用堆棧管理模塊以及調(diào)試命令解析模塊。本發(fā)明還涉及一種基于該系統(tǒng)實現(xiàn)企業(yè)Web應用系統(tǒng)中跨瀏覽器Javascript調(diào)試的方法。采用該種企業(yè)Web應用系統(tǒng)中實現(xiàn)跨瀏覽器Javascript調(diào)試的系統(tǒng)及其方法,調(diào)試效率高,操作簡單快捷方便,系統(tǒng)性能穩(wěn)定可靠,降低了開發(fā)維護成本,增強了系統(tǒng)可移植性和可擴展性,適用范圍較為廣泛,為企業(yè)Web應用軟件技術的進一步發(fā)展奠定了堅實的基礎。文檔編號G06F11/36GK101719093SQ20091020018公開日2010年6月2日申請日期2009年12月9日優(yōu)先權日2009年12月9日發(fā)明者曹宗偉,焦烈焱,馬捷申請人:上海普元信息技術有限責任公司