欧美在线观看视频网站,亚洲熟妇色自偷自拍另类,啪啪伊人网,中文字幕第13亚洲另类,中文成人久久久久影院免费观看 ,精品人妻人人做人人爽,亚洲a视频

根據(jù)用戶的需求格式化輸出及操作伺服端業(yè)務數(shù)據(jù)的方法

文檔序號:6334225閱讀:697來源:國知局
專利名稱:根據(jù)用戶的需求格式化輸出及操作伺服端業(yè)務數(shù)據(jù)的方法
技術(shù)領(lǐng)域
本發(fā)明涉及一種自助建站、互聯(lián)網(wǎng)開放平臺、云計算、互聯(lián)網(wǎng)在線應用服務及 軟件開發(fā)、軟件及服務SAAS、數(shù)據(jù)交換的方法,更具體地說,涉及一種根據(jù)用戶的需求 格式化輸出及操作伺服端業(yè)務數(shù)據(jù)的方法。
背景技術(shù)
隨著Facebook通過開放平臺而一炮走紅,全球各大互聯(lián)網(wǎng)公司開始競相推出 自己的開放平臺戰(zhàn)略,國內(nèi)外對開放平臺的前景一片看好。開放平臺(OpenPlatform) 在軟件業(yè)和網(wǎng)絡中,開放平臺是指軟件系統(tǒng)通過公開其應用程序編程接口(API)或過程 (function)來使外部的程序可以增加該軟件系統(tǒng)的功能或使用該軟件系統(tǒng)的資源,而不需 要更改該軟件系統(tǒng)的源代碼。目前開放平臺主要通過以下幾種技術(shù)手段實現(xiàn)平臺數(shù)據(jù)的 開放,與第三方的數(shù)據(jù)交換,搭建一些和該網(wǎng)站業(yè)務相關(guān)的應用。(l)REST。REST 是英文 Representational State Transfer 的縮寫,中文翻譯為“表 述性狀態(tài)轉(zhuǎn)移”,他是由Roy Thomas Fielding博士在他的論文《Architectural Styles and the Design of Network-based Software Architectures》中提出的一個術(shù)語。REST 本身只是
為分布式超媒體系統(tǒng)設計的一種架構(gòu)風格,而不是標準。REST架構(gòu)是針對Web應用而設計的,其目的是為了降低開發(fā)的復雜性,提高 系統(tǒng)的可伸縮性。REST提出了如下設計準則1.網(wǎng)絡上的所有事物都被抽象為資源 (resource) ; 2.每個資源對應一個唯一的資源標識符(resource identifier) ; 3.通過通用的連 接器接口(generic connector interface)對資源進行操作;4.對資源的各種操作不會改變資 源標識符;5.所有的操作都是無狀態(tài)的(stateless)。REST中的資源所指的不是數(shù)據(jù),而是數(shù)據(jù)和表現(xiàn)形式的組合,比如“最新 訪問的10位會員”和“最活躍的10為會員”在數(shù)據(jù)上可能有重疊或者完全相同,而 由于他們的表現(xiàn)形式不同,所以被歸為不同的資源,這也就是為什么REST的全名是 Representational State Transfer 的原因。資源標識符就是 URI (Uniform Resource Identifier), 不管是圖片,Word還是視頻文件,甚至只是一種虛擬的服務,也不管你是xml格式,txt 文件格式還是其它文件格式,全部通過URI對資源進行唯一的標識。REST是基于Http協(xié)議的,任何對資源的操作行為都是通過Http協(xié)議來實現(xiàn)。目前,51,校內(nèi),海內(nèi),阿里軟件等都通過REST架構(gòu)來實現(xiàn)開放平臺。(2) Widget 微件,比較典型的例子有 Yahoo !的 Widgets,Google 的 Gadgets 和 Netvibes的UWA等。widget分類很多,作為Internet用戶而不是開發(fā)者,我們常用的有 用于網(wǎng)頁的Web Widget和用于操作系統(tǒng)的Desktop widget兩種Web Widget是一種HTML代碼,可以嵌入到網(wǎng)頁上,舉例Yahoo ! widget, iGoogle Gadget,豆辧 API。 Wikipedia web widget 說又稱為 badge, module, webjit, capsule, snippet, mini and flake.DHTML, JavaScript, Adobe Flash。Desktop widget 是運行在 PC 操作系統(tǒng)上的微件,例如 Apple dashboard widget,Windows Sidebar and gadgets, Google desktop sidebar (Google 桌面搜索側(cè)欄)上的一個一 個小應用,通常涉及到一個概念widget engine,即widget的運行環(huán)境。(3)OpenSocial。OpenSocial為構(gòu)建跨多個網(wǎng)站的社交應用程序提供了一組通用 API。開發(fā)人員可以使用標準JavaScript和HTML創(chuàng)建應用程序,用以訪問社交網(wǎng)絡里的 朋友并更新對應的Feeds。Opensocial為社交網(wǎng)站提供了一套統(tǒng)一的社交網(wǎng)絡框架與開發(fā) 模型。(4)Mashup是糅合,是當今網(wǎng)絡上新出現(xiàn)的一種網(wǎng)絡現(xiàn)象,將兩種以上使用公 共或者私有數(shù)據(jù)庫的web應用,加在一起,形成一個整合應用。(5)云計算,Google 的 App Engine 和 Amazon 的 EC2 和 S3 等。

發(fā)明內(nèi)容
本發(fā)明的目的是提供一種能夠?qū)崿F(xiàn)在線開發(fā),服務商拓展應用服務便捷,代碼 靈活,服務商開放數(shù)據(jù)接口(API)更容易,基于該腳本語言與云計算模式,應用服務系 統(tǒng)之間的數(shù)據(jù)交換、服務整合、協(xié)同應用靈活而且規(guī)范的根據(jù)用戶的需求格式化輸出及 操作伺服端業(yè)務數(shù)據(jù)的方法。本發(fā)明的技術(shù)方案是這樣的一種根據(jù)用戶的需求格式化輸出及操作伺服端業(yè)務數(shù)據(jù)的方法,方法如下(1)選定腳本語言及腳本語言執(zhí)行引擎;(2)用戶使用上述的語言根據(jù)業(yè)務需求編寫腳本代碼;(3)客戶端把腳本代碼發(fā)送或保存到伺服端;(4)由伺服端腳本語言執(zhí)行引擎執(zhí)行上述的腳本代碼;(5)執(zhí)行的結(jié)果數(shù)據(jù)輸出返回給客戶端。所述的腳本語言是格式化腳本語言(GScript)。所述的執(zhí)行引擎是格式化腳本語言執(zhí)行引擎(GScriptEngine),用于接收傳入的 腳本代碼,結(jié)合緩存會話(context)與請求(request)進行解析、執(zhí)行代碼,在解析執(zhí)行過 程中根據(jù)代碼指令依次封裝輸出用戶所需的數(shù)據(jù)。所述的緩存會話(context)存儲引用操作結(jié)構(gòu)化/非結(jié)構(gòu)化數(shù)據(jù)庫的指針、引用 操作文件/緩存數(shù)據(jù)/其它數(shù)據(jù)資源的指針、弓I用操作CPU/其它硬件設備的指針,以及 存儲在代碼過程中根據(jù)用戶指令臨時產(chǎn)生的變量。所述的請求(request)存儲頁面請求的參數(shù)名與參數(shù)值。所述的格式化腳本語言執(zhí)行引擎(GScriptEngine)入口參數(shù)主要包含腳本代碼輸 入流(inputstream)、緩存會話(context)、請求(request)、輸出編碼(encoding)、結(jié)果數(shù)據(jù) 輸出流(outputstream)、啟用調(diào)試模式(debug)。所述的格式化腳本語言執(zhí)行引擎解析代碼的算法是變_分的方法,所述的變是 指文本字符串不斷的經(jīng)過匹配替換而變成新的字符串,所述的分是指被替換的字符串進 行分隔演變成多個新的字符串,算法按變_分-變-分-變循環(huán)處理。所述的格式化腳本語言執(zhí)行引擎處理代碼的過程步驟如下(1)將腳本代碼輸入流轉(zhuǎn)換成文本字符串;(2)根據(jù)腳本指令函數(shù)語法變_分處理依次形成指令函數(shù)集合;
5
(3)按順序依次執(zhí)行指令函數(shù);(4)指令函數(shù)計算的結(jié)果根據(jù)指令函數(shù)的特性依次封裝輸出用戶所需的數(shù)據(jù)。所述的指令函數(shù)順序為先執(zhí)行其函數(shù)參數(shù)集合,而后依次執(zhí)行函數(shù)體內(nèi)部的 子指令函數(shù)。指令函數(shù)參數(shù)集合執(zhí)行時,對參數(shù)字符串進行分處理,依次分割成多個參數(shù)字 符串,然后進行變處理。所述的執(zhí)行的結(jié)果數(shù)據(jù)的格式基于用戶編寫的腳本代碼指令。所述的業(yè)務數(shù)據(jù)的輸出內(nèi)容及格式可以是XML、JSON、XML+XSL、 XML+XSLT。腳本代碼發(fā)送或保存到伺服端的步驟是由服務商提供入口,通過網(wǎng)絡傳送或 保存至伺服端;當客戶端請求訪問腳本代碼時伺服端會自動調(diào)用腳本語言執(zhí)行引擎對其 解析、執(zhí)行,并返回結(jié)果數(shù)據(jù)。通過指令函數(shù)調(diào)用引用指針的屬性或方法對業(yè)務數(shù)據(jù)進行操作,將執(zhí)行的結(jié)果 數(shù)據(jù)再通過指令函數(shù)格式化輸出?;谀_本語言擴展開放數(shù)據(jù)接口(API),可以通過擴展指令函數(shù),或通過在緩存 會話(context)中引入對象指針的方式很容易擴展數(shù)據(jù)接口,或定義類名使用assign指令 函數(shù)構(gòu)造類對象。腳本代碼在伺服端的信任采用PKI安全體系及技術(shù)。伺服端解析執(zhí)行腳本代碼的安全防護方法可以如下(1)引擎本身確保解析過程的安全,指令函數(shù)執(zhí)行的安全,采用的方法為白盒測 試、黑盒測試;或(2)引用的對象指針使用安全策略文件限定可訪問的屬性與方法;或(3)在腳本語言執(zhí)行引擎的運行時環(huán)境環(huán)境中加入安全策略;或(4)監(jiān)控腳本代碼的解析執(zhí)行情況。所述的安全策略可以是(1)使用沙盒,讓腳本代碼解析執(zhí)行在受限的沙盒中運行;或(2)處理時長計時,控制解析執(zhí)行腳本代碼的時間,達到限制時間后,處理將中 斷;或(3)限制腳本代碼的文件大小、語句數(shù)量;或(4)限制臨時變量緩存的數(shù)量及大小,或者使用硬盤緩存策略;或(5)利用線程空閑及睡眠sleep控制CPU占用率;或(6)控制存在循環(huán)因素的指令函數(shù)被循環(huán)調(diào)用的次數(shù);或(7)采用虛擬機。本發(fā)明的有益效果如下(1)沿襲開發(fā)者使用代碼編寫程序的習慣,開辟軟件開發(fā)新模式——在線開發(fā) 開發(fā)者在瀏覽器上就可以編碼、測試、完成應用開發(fā)。(2)之所以稱之為腳本,即無需在伺服端上進行部署,非常便捷的為服務商拓展 應用服務。(3)代碼的靈活性更加靈活滿足用戶多變的需求。
(4)基于該腳本語言更容易使得服務商開放數(shù)據(jù)接口(API)。(5)云計算模式用戶即可通過網(wǎng)絡以按需、易擴展的方式——腳本獲得所需的 資源。用戶端只需要編寫需求腳本以及展現(xiàn)數(shù)據(jù),把計算交給服務器。使得用戶終端簡 化成一個單純的輸入輸出設備,且按需享受服務器端(“云”)的強大計算處理能力。(6)通過腳本非常靈活而且規(guī)范的實現(xiàn)多個應用服務系統(tǒng)之間的數(shù)據(jù)交換、服務 整合、協(xié)同應用等。


圖1是本發(fā)明實現(xiàn)平臺數(shù)據(jù)的開放,完成與第三方的數(shù)據(jù)交換的示意圖。 圖2是本發(fā)明實施例的效果圖。
具體實施例方式下面結(jié)合實施例對本發(fā)明進行進一步詳細說明一種根據(jù)用戶的需求格式化輸出及操作伺服端業(yè)務數(shù)據(jù)的方法,方法如下(1)選定腳本語言及腳本語言執(zhí)行引擎;(2)用戶使用上述的語言根據(jù)業(yè)務需求編寫腳本代碼;(3)客戶端把腳本代碼發(fā)送或保存到伺服端;(4)由伺服端腳本語言執(zhí)行引擎執(zhí)行上述的腳本代碼;(5)執(zhí)行的結(jié)果數(shù)據(jù)輸出返回給客戶端。所述的腳本語言是格式化腳本語言(GScript)。所述的執(zhí)行引擎是格式化腳本語言執(zhí)行引擎(GScriptEngine),用于接收傳入的 腳本代碼,結(jié)合緩存會話(context)與請求(request)進行解析、執(zhí)行代碼,在解析執(zhí)行過 程中根據(jù)代碼指令依次封裝輸出用戶所需的數(shù)據(jù)。所述的緩存會話(context)存儲引用操作結(jié)構(gòu)化/非結(jié)構(gòu)化數(shù)據(jù)庫的指針、引用 操作文件/緩存數(shù)據(jù)/其它數(shù)據(jù)資源的指針、弓I用操作CPU/其它硬件設備的指針,以及 存儲在代碼過程中根據(jù)用戶指令臨時產(chǎn)生的變量。所述的請求(request)存儲頁面請求的參數(shù)名與參數(shù)值。所述的格式化腳本語言執(zhí)行引擎(GScriptEngine)入口參數(shù)主要包含腳本代碼輸 入流(inputstream)、緩存會話(context)、請求(request)、輸出編碼(encoding)、結(jié)果數(shù)據(jù) 輸出流(outputstream)、啟用調(diào)試模式(debug)。所述的格式化腳本語言執(zhí)行引擎解析代碼的算法是變_分的方法,所述的變是 指文本字符串不斷的經(jīng)過匹配替換而變成新的字符串,所述的分是指被替換的字符串進 行分隔演變成多個新的字符串,算法按變_分-變-分-變循環(huán)處理。所述的格式化腳本語言執(zhí)行引擎處理代碼的過程步驟如下(1)將腳本代碼輸入流轉(zhuǎn)換成文本字符串;(2)根據(jù)腳本指令函數(shù)語法變_分處理依次形成指令函數(shù)集合;(3)按順序依次執(zhí)行指令函數(shù);(4)指令函數(shù)計算的結(jié)果根據(jù)指令函數(shù)的特性依次封裝輸出用戶所需的數(shù)據(jù)。所述的指令函數(shù)順序為先執(zhí)行其函數(shù)參數(shù)集合,而后依次執(zhí)行函數(shù)體內(nèi)部的 子指令函數(shù)。
指令函數(shù)參數(shù)集合執(zhí)行時,對參數(shù)字符串進行分處理,依次分割成多個參數(shù)字 符串,然后進行變處理。所述的執(zhí)行的結(jié)果數(shù)據(jù)的格式基于用戶編寫的腳本代碼指令。所述的業(yè)務數(shù)據(jù)的輸出內(nèi)容及格式可以是XML、JSON、XML+XSL、 XML+XSLT。腳本代碼發(fā)送或保存到伺服端的步驟是由服務商提供入口,通過網(wǎng)絡傳送或 保存至伺服端;當客戶端請求訪問腳本代碼時伺服端會自動調(diào)用腳本語言執(zhí)行引擎對其 解析、執(zhí)行,并返回結(jié)果數(shù)據(jù)。通過指令函數(shù)調(diào)用引用指針的屬性或方法對業(yè)務數(shù)據(jù)進行操作,將執(zhí)行的結(jié)果 數(shù)據(jù)再通過指令函數(shù)格式化輸出?;谀_本語言擴展開放數(shù)據(jù)接口(API),可以通過擴展指令函數(shù),或通過在緩存 會話(context)中引入對象指針的方式很容易擴展數(shù)據(jù)接口,或定義類名使用assign指令 函數(shù)構(gòu)造類對象。腳本代碼在伺服端的信任采用PKI安全體系及技術(shù)。伺服端解析執(zhí)行腳本代碼的安全防護方法可以如下(1)引擎本身確保解析過程的安全,指令函數(shù)執(zhí)行的安全,采用的方法為白盒測 試、黑盒測試;或(2)引用的對象指針使用安全策略文件限定可訪問的屬性與方法;或(3)在腳本語言執(zhí)行引擎的運行時環(huán)境環(huán)境中加入安全策略;或(4)監(jiān)控腳本代碼的解析執(zhí)行情況。引擎本身解析的過程,經(jīng)過(1)嚴格測試,以及(2)對變分方法每個環(huán)節(jié)進行驗 證確保解析過程的安全。另外其解析過程仍然受限在第15所述的安全策略中。指令函數(shù)執(zhí)行的安全,也是類似,(1)嚴格測試(2)對輸入的參數(shù)進行嚴格驗證 確保執(zhí)行的安全。針對測試,采用黑盒測試。通過使用整個軟件或某種軟件功能來嚴格地測試, 而并沒有通過檢查程序的源代碼或者很清楚地了解該軟件或某種軟件功能的源代碼程序 具體是怎樣設計的。測試人員通過輸入他們的數(shù)據(jù)然后看輸出的結(jié)果從而了解軟件怎樣 工作。通常測試人員在進行測試時不僅使用肯定出正確結(jié)果的輸入數(shù)據(jù),而且還會使用 有挑戰(zhàn)性的輸入數(shù)據(jù)以及可能結(jié)果會出錯的輸入數(shù)據(jù)以便了解軟件怎樣處理各種類型的 數(shù)據(jù)。針對驗證,采用白盒測試。通過程序的源代碼進行測試而不使用用戶界面。這 種類型的測試需要從代碼句法發(fā)現(xiàn)內(nèi)部代碼在算法,溢出,路徑,條件等等中的缺點或 者錯誤,進而加以修正。另外其執(zhí)行過程還受限在如下安全策略中。在腳本語言執(zhí)行引擎的運行時環(huán)境環(huán)境中加入的安全策略可以是(1)使用沙盒,讓腳本代碼解析執(zhí)行在受限的沙盒中運行;或(2)處理時長計時,控制解析執(zhí)行腳本代碼的時間,達到限制時間后,處理將中 斷;或(3)限制腳本代碼的文件大小、語句數(shù)量;或
(4)限制臨時變量緩存的數(shù)量及大小,或者使用硬盤緩存策略;或(5)利用線程空閑及睡眠sleep控制CPU占用率;或(6)控制存在循環(huán)因素的指令函數(shù)被循環(huán)調(diào)用的次數(shù);或(7)采用虛擬機。如圖1所示,實現(xiàn)平臺數(shù)據(jù)的開放,完成與第三方的數(shù)據(jù)交換,滿足搭建一些 和該網(wǎng)站業(yè)務相關(guān)的應用需求。客戶端,或稱為用戶端(Client)。在計算機的世界里,凡是提供服務的一方我們 稱為伺服端(Server),而接受服務的另一方我們稱作客戶端(Client)。因此這里所指的客 戶端不局限于瀏覽器。如果一個伺服端相對于另外一個伺服端是請求或接受服務的話, 那么這個伺服端也被認為是另一個伺服端的客戶端。這里所指的客戶端與伺服端所處的硬件設備不局限于計算機,還應包括嵌入式 設備等。格式化腳本語言,所謂格式化,其意目的就在于按照用戶的意圖格式化輸出數(shù) 據(jù)。因此我們?yōu)檫@種腳本語言提供了指令函數(shù),能夠以XML的格式按照用戶的需要將伺 服端的各種數(shù)據(jù)資源進行計算并輸出。這就是與其它語言有著很大的不同?,F(xiàn)版本已升 級到2.0.5版本。GScript腳本主要以代碼為形式,類似于js腳本,腳本文件則以.gs為后綴。GScript腳本還存在XML的形式,但不推薦開發(fā)者使用,僅用于約束規(guī)范。其 腳本文件以.gsxml為后綴。GScript腳本由指令函數(shù)、操作符、運算函數(shù)構(gòu)成,其中指令函數(shù)為主體。 GScript腳本代碼指令實際上就是一系列指令函數(shù)的集合。所以GScript代碼指令的形式 非常簡單,為<函數(shù)名 >(〈函數(shù)參數(shù)1>,<函數(shù)參數(shù)2>,……){<函數(shù)體>};指令函數(shù)使用;作為結(jié)束符。函數(shù)名后面的參數(shù)是用0包裹起來,多個參數(shù) 之間用,隔開。并非所有函數(shù)都有參數(shù)。如無參數(shù)則0可省略。函數(shù)體用 包裹起 來。函數(shù)體內(nèi)部則可書寫多個指令函數(shù)。并非所有函數(shù)都有函數(shù)體。如無函數(shù)體則 可省略。腳本語言執(zhí)行引擎(GScriptEngine)的核心作用在于接收傳入的腳本代碼,結(jié)合 緩存會話(context)與請求(request)進行解析、執(zhí)行代碼,在解析執(zhí)行過程中根據(jù)代碼指 令依次封裝輸出用戶所需的數(shù)據(jù)。a)緩存會話(context)存儲引用操作結(jié)構(gòu)化/非結(jié)構(gòu)化數(shù)據(jù)庫的指針、引用操作 文件/緩存數(shù)據(jù)/其它數(shù)據(jù)資源的指針、引用操作CPU/其它硬件設備的指針等等。以 及存儲在代碼過程中根據(jù)用戶指令臨時產(chǎn)生的變量。b)請求(request)存儲頁面請求的參數(shù)名與參數(shù)值。GScriptEngine入口參數(shù)主要為腳本代碼輸入流(inputstream)、緩存會話 (context)、請求(request)、輸出編碼(encoding)、結(jié)果數(shù)據(jù)輸出流(outputstream)、啟用 調(diào)試模式(debug)。
示例JAVA代碼
voidwrite(
//腳本代碼輸入流(inputstream)[Ol 24]java.io.InputStream is,[Ol 25]//緩存會話(context)[Ol 26]java.util.Map<String,Object>context,
//請求(request)[Ol 28]com.onegrid.grid.platform.gscript.HGScriptRequest request,
//輸出編碼(encoding)[Ol 303String encoding,[Ol 31]//結(jié)果數(shù)據(jù)輸出流(outputstream)[Ol 32]java.io.OutputStream OS,
//啟用調(diào)試模式(debug)[Ol 343boolean debug
35])throws HGSCriptEXCeption;
GScriptEngine解析代碼的算法是采用變一分的方法。
a)變是指文本字符串不斷的經(jīng)過匹配替換而變成新的字符串。
例如文本中用()包裹起來的,或者用{}包裹起來的,或者用[]包裹起來的被替換成新的字符串例如#(0_0)。
b)分是指被替換的字符串經(jīng)過, ; 一等進行分隔演變成多個新的字符串。
例如文本中用()包裹起來的字符串其被,進行分隔成多個新的字符串。,常用于參數(shù)分隔, ;常用于語句分隔,一常用于范圍分隔。[Ol 39] 依次變一分一變一分一變?nèi)缡翘幚怼?br> GScriptEngine處理代碼的過程步驟如下
a)將腳本代碼輸入流轉(zhuǎn)換成文本字符串。
此過程中過濾注釋語句。
b)根據(jù)腳本指令函數(shù)語法函數(shù)名(函數(shù)參數(shù)集合){函數(shù)體}進行對(){}進行變以及對;進行分依次形成指令函數(shù)集合。
這里僅對第一層()做變,對()的內(nèi)部()不做任何變化。
而對{}及其內(nèi)部{}均做變。;根據(jù)語法僅存在函數(shù)體內(nèi)。
由此函數(shù)體內(nèi)通過;分隔形成了多個子指令函數(shù)。
assign(“a”, “/default/entity/ThingQueryHelper”){
453setProperty(“pagesize”,20);[Ol 46]setProperty( “CUlTOW”,0);
}[Ol 48] 處理時變化如下
0 assign#(0_0)#{o一0}一整句,對(){}變
l0一#{o—o},對;分[Ol 51] 20一setProperty#(O一1) 一對()變
30一setProperty#(O一2) 一對()變
c)按順序依次執(zhí)行指令函數(shù)。指令函數(shù)先執(zhí)行其函數(shù)參數(shù)集合,而后依次函數(shù) 體內(nèi)部的子指令函數(shù)。d)指令函數(shù)參數(shù)集合執(zhí)行時,對0內(nèi)的參數(shù)字符串對,進行分則依次被分割成 多個參數(shù)字符串,然后對內(nèi)部的0進行變。參數(shù)字符串根據(jù)腳本操作符語法以及優(yōu)先 級、腳本運算函數(shù)進行計算。計算后的結(jié)果依次作為該指令函數(shù)的參數(shù)。對于[]數(shù)組范 圍也如是處理。示例assign( “a”,((1+2)+3));處理時執(zhí)行如下0 assign#(0_0) 一整句,對()變1I一#(0_0),對,分以及對內(nèi)部()變2 卜“a” 一計算結(jié)果字符串a(chǎn)3 |-#(0_1) 一對字符串(1+2)+3 內(nèi)部()再變4I 一 #{0_2}+35 卜 #(0_2)—1+26 卜3—計算結(jié)果數(shù)字37卜3—計算結(jié)果數(shù)字3e)指令函數(shù)計算的結(jié)果根據(jù)指令函數(shù)的特性依次封裝輸出用戶所需的數(shù)據(jù)。例 如out指令函數(shù)專用于輸出結(jié)果數(shù)據(jù)。并不是所有的指令函數(shù)都具備封裝輸出結(jié)果數(shù)據(jù)的 特性。輸出的結(jié)果數(shù)據(jù)根據(jù)指令函數(shù)上下關(guān)系存在一定的格式規(guī)范例如XML。這種格 式很容易在客戶端被解析處理。GScriptEngine使用@操作符引用緩存會話(context)存儲的各種指針與變量。指
針或變量被引用時可使用.操作符取其屬性或執(zhí)行方法。獲取后的屬性值或執(zhí)行方法后的 結(jié)果同是可通過使用.操作符被取其屬性或執(zhí)行方法。示例以下context為緩存會話(context)存儲的引用事務會話的指針1 @context.actionLanguage一 actionLanguage 為 context 的屬'性2 @context.pageLink( “1234567890” ) 一 pageLink 為 context 的方法3 @context.sessionContext.logged 一 sessionContext 為 context 的屬性— logged 為屬性 sessionContext 的屬性4 @context.transfer.stringldentity ( “1234567890” ) 一 transfer 為 context 的屬 性— stringldentity 為屬性transfer 的方法5 @context.transfer.hadoopFile ( “1234567890” ) .accessLink— transfer 為 context 的屬性— hadoopFile 為屬性 transfer 的方法— accessLink為屬性transfer的方法hadoopFile執(zhí)行后的結(jié)果對象指針的屬性以上方式為服務商擴展開放數(shù)據(jù)接口(API)提供了基礎。
·可限定屬性與方法的特性,例如在JAVA代碼中通常會使用JAVABEAN的特 性,限定屬性與方法只能取getXxx,isXxx形式的?!ひ部赏ㄟ^安全策略policy文件限定哪些屬性與方法能被獲取或執(zhí)行。該文件 可根據(jù)具體需求進行自定義。示例< ? xml version=" 1.0〃 ? >〈policy〉〈deny class=" java.lang.Class" mode=" GET" />〈/policy〉以上策略文件限定JAVA代碼中java.lang.dass下的所有屬性與方法都不能被獲取
或執(zhí)行。GScriptEngine使用$操作符獲取頁面請求(request)的參數(shù)值。示例1 SparamName —獲取請求參數(shù)參數(shù)名為paramName的參數(shù)值GScriptEngine當在指針名、變量名、參數(shù)名前都不加$操作符與@操作符時, 默認先以參數(shù)名的形式從請求(request)中獲取參數(shù)值,而后在緩存會話(context)中獲取 引用的指針或變量。腳本代碼如何發(fā)送或保存到伺服端。由服務商提供入口,可通過網(wǎng)絡(例如HTTP、FTP)傳送至伺服端。當客戶端 請求訪問該腳本代碼時伺服端會自動調(diào)用腳本語言執(zhí)行引擎對其解析、執(zhí)行,并返回結(jié) 果數(shù)據(jù)。輸出業(yè)務數(shù)據(jù)。業(yè)務數(shù)據(jù)的輸出內(nèi)容及格式基于用戶編寫的腳本代碼指令,極大程度上提供了 數(shù)據(jù)獲取的靈活性。格式化腳本語言GScript默認提供輸出格式為XML。XML即擴展 標記語言,是一種簡單的數(shù)據(jù)存儲語言,使用一系列簡單的標記描述數(shù)據(jù),極其簡單易 于掌握和使用。它的簡單使其易于在任何應用程序中讀寫數(shù)據(jù),這使XML很快成為數(shù)據(jù) 交換的唯一公共語言。示例out( “bookstore,,){out( “book,,){out( “title,,, "C++Programming Language");}}輸出的結(jié)果為< ? xml version=,,1.0” ? ><data>〈bookstore〉<book><title>C++Programming Language</title>
</book></bookstore></data>XML格式的數(shù)據(jù)很容易跟其它任何一種應用程序進行交互。而且結(jié)合XSL (可 擴展樣式表語言)很容易轉(zhuǎn)換成其它格式文檔例如HTML、XHTML或者文本。我們在 公司研發(fā)的格子平臺上就充分應用了 XML+XSLT。(5)操作業(yè)務數(shù)據(jù)。通過指令函數(shù)例如void調(diào)用引用指針的屬性或方法從而達到添加、刪除、修改 業(yè)務數(shù)據(jù)的目的。將執(zhí)行的結(jié)果數(shù)據(jù)再通過指令函數(shù)格式化輸出。(6)基于腳本語言擴展服務商開放數(shù)據(jù)接口(API)。服務商可以通過①擴展指令函數(shù),或②通過在緩存會話(context)中引入對象指 針的方式很容易擴展數(shù)據(jù)接口(API),或③定義類名使用assign指令函數(shù)構(gòu)造類對象。 我們目前已在公司研發(fā)的格子平臺上①擴展ess (為網(wǎng)頁加載樣式文件)、js (為網(wǎng)頁加載 javascript腳本文件)、text (獲取國際化語言)等指令函數(shù),②也以插件(plugin)形式提 供email(郵件發(fā)送)、xml(XML格式文檔處理)的功能應用,③同時也提供了很多的類 名例如查詢器” /default/entity/ThingQueryHelper” 構(gòu)造類對象。腳本代碼在伺服端的信任。采用現(xiàn)有公認的PKI安全體系及技術(shù)就可有效解決腳本代碼在伺服端的信任問題。伺服端解析執(zhí)行腳本代碼的安全防護。伺服端解析執(zhí)行腳本代碼的安全與引用的對象指針有關(guān),與腳本語言執(zhí)行引擎
等有關(guān)。(1)引擎本身確保解析過程的安全,指令函數(shù)執(zhí)行的安全。(2)引用的對象指針可以使用安全策略文件限定可訪問的屬性與方法。(3)腳本語言執(zhí)行引擎。其所在的運行時環(huán)境例如JAVA語言其所需JVM虛擬 機。(4)可在運行時環(huán)境中加入安全策略。(4.1)使用沙盒。讓腳本代碼解析執(zhí)行在受限的沙盒中運行。(4.3)處理時長計時??刂平馕鰣?zhí)行腳本代碼的時間。達到限制時間后,處理 將中斷。(4.4)限制腳本代碼的文件大小、語句數(shù)量。(4.5)限制臨時變量緩存的數(shù)量及大小,或者使用硬盤緩存策略。(4.6)利用線程空閑及睡眠sleep控制CPU占用率。(4.7)控制存在循環(huán)因素的指令函數(shù)被循環(huán)調(diào)用的次數(shù)。(4.8)采用虛擬機。(4.9)其它安全措施。(5)監(jiān)控腳本代碼的解析執(zhí)行情況,輔助安全防護。本發(fā)明流程中對應的信息輸入、輸出如下1、編寫腳本代碼;
2、XML格式輸出;3、腳本代碼運行時GScriptEngine解析與執(zhí)行的調(diào)試信息;4、使用以下XLST轉(zhuǎn)換GScript輸出的XML格式數(shù)據(jù);5、轉(zhuǎn)換后的效果圖,如圖2所示。以上所述的僅是本發(fā)明的優(yōu)選實施方式,應當指出,對于本技術(shù)領(lǐng)域中的普通 技術(shù)人員來說,在不脫離本發(fā)明核心技術(shù)特征的前提下,還可以做出若干改進和潤飾, 這些改進和潤飾也應視為本發(fā)明的保護范圍。
權(quán)利要求
1.一種根據(jù)用戶的需求格式化輸出及操作伺服端業(yè)務數(shù)據(jù)的方法,其特征在于,方 法如下(1)選定腳本語言及腳本語言執(zhí)行引擎;(2)用戶使用上述的語言根據(jù)業(yè)務需求編寫腳本代碼;(3)客戶端把腳本代碼發(fā)送或保存到伺服端;(4)由伺服端腳本語言執(zhí)行引擎執(zhí)行上述的腳本代碼;(5)執(zhí)行的結(jié)果數(shù)據(jù)輸出返回給客戶端。
2.根據(jù)權(quán)利要求1所述的方法,其特征在于,所述的腳本語言是格式化腳本語言 (GScript)。
3.根據(jù)權(quán)利要求1所述的方法,其特征在于,所述的執(zhí)行引擎是格式化腳本語言 執(zhí)行引擎(GScriptEngine),用于接收傳入的腳本代碼,結(jié)合緩存會話(context)與請求 (request)進行解析、執(zhí)行代碼,在解析執(zhí)行過程中根據(jù)代碼指令依次封裝輸出用戶所需 的數(shù)據(jù)。
4.根據(jù)權(quán)利要求3所述的方法,其特征在于,所述的緩存會話(context)存儲引用操 作結(jié)構(gòu)化/非結(jié)構(gòu)化數(shù)據(jù)庫的指針、引用操作文件/緩存數(shù)據(jù)/其它數(shù)據(jù)資源的指針、 引用操作CPU/其它硬件設備的指針,以及存儲在代碼過程中根據(jù)用戶指令臨時產(chǎn)生的變量。
5.根據(jù)權(quán)利要求3所述的方法,其特征在于,所述的請求(request)存儲頁面請求的參數(shù)名與參數(shù)值。
6.根據(jù)權(quán)利要求3所述的方法,其特征在于,所述的格式化腳本語言執(zhí)行引擎 (GScriptEngine)入口參數(shù)主要包含腳本代碼輸入流(inputstream)、緩存會話(context)、 請求(request)、輸出編碼(encoding)、結(jié)果數(shù)據(jù)輸出流(outputstream)、啟用調(diào)試模式 (debug)。
7.根據(jù)權(quán)利要求3所述的方法,其特征在于,所述的格式化腳本語言執(zhí)行引擎解 析代碼的算法是變-分的方法,所述的變是指文本字符串不斷的經(jīng)過匹配替換而變成 新的字符串,所述的分是指被替換的字符串進行分隔演變成多個新的字符串,算法按 變-分-變-分-變循環(huán)處理。
8.根據(jù)權(quán)利要求3所述的方法,其特征在于,所述的格式化腳本語言執(zhí)行引擎處理代 碼的過程步驟如下(1)將腳本代碼輸入流轉(zhuǎn)換成文本字符串;(2)根據(jù)腳本指令函數(shù)語法變_分處理依次形成指令函數(shù)集合;(3)按順序依次執(zhí)行指令函數(shù);(4)指令函數(shù)計算的結(jié)果根據(jù)指令函數(shù)的特性依次封裝輸出用戶所需的數(shù)據(jù)。
9.根據(jù)權(quán)利要求8所述的方法,其特征在于,所述的指令函數(shù)順序為先執(zhí)行其函 數(shù)參數(shù)集合,而后依次執(zhí)行函數(shù)體內(nèi)部的子指令函數(shù)。
10.根據(jù)權(quán)利要求9所述的方法,其特征在于,指令函數(shù)參數(shù)集合執(zhí)行時,對參數(shù)字 符串進行分處理,依次分割成多個參數(shù)字符串,然后進行變處理。
11.根據(jù)權(quán)利要求1所述的方法,其特征在于,所述的執(zhí)行的結(jié)果數(shù)據(jù)的格式基于用 戶編寫的腳本代碼指令。
12.根據(jù)權(quán)利要求11所述的方法,其特征在于,所述的業(yè)務數(shù)據(jù)的輸出內(nèi)容及格式可 以是 XML、JSON、XML+XSL、XML+XSLT。
13.根據(jù)權(quán)利要求1所述的方法,其特征在于,腳本代碼發(fā)送或保存到伺服端的步驟 是由服務商提供入口,通過網(wǎng)絡傳送或保存至伺服端;當客戶端請求訪問腳本代碼時 伺服端會自動調(diào)用腳本語言執(zhí)行引擎對其解析、執(zhí)行,并返回結(jié)果數(shù)據(jù)。
14.根據(jù)權(quán)利要求1所述的方法,其特征在于,通過指令函數(shù)調(diào)用引用指針的屬性或 方法對業(yè)務數(shù)據(jù)進行操作,將執(zhí)行的結(jié)果數(shù)據(jù)再通過指令函數(shù)格式化輸出。
15.根據(jù)權(quán)利要求1所述的方法,其特征在于,基于腳本語言擴展開放數(shù)據(jù)接口 (API),可以通過擴展指令函數(shù),或通過在緩存會話(context)中引入對象指針的方式很 容易擴展數(shù)據(jù)接口,或定義類名使用assign指令函數(shù)構(gòu)造類對象。
16.根據(jù)權(quán)利要求1所述的方法,其特征在于,腳本代碼在伺服端的信任采用PKI安 全體系及技術(shù)。
17.根據(jù)權(quán)利要求1所述的方法,其特征在于,伺服端解析執(zhí)行腳本代碼的安全防護 方法可以如下(1)引擎本身確保解析過程的安全,指令函數(shù)執(zhí)行的安全,采用的方法為白盒測試、 黑盒測試;或(2)引用的對象指針使用安全策略文件限定可訪問的屬性與方法;或(3)在腳本語言執(zhí)行引擎的運行時環(huán)境環(huán)境中加入安全策略;或(4)監(jiān)控腳本代碼的解析執(zhí)行情況。
18.根據(jù)權(quán)利要求17所述的方法,其特征在于,所述的安全策略可以是(1)使用沙盒,讓腳本代碼解析執(zhí)行在受限的沙盒中運行;或(2)處理時長計時,控制解析執(zhí)行腳本代碼的時間,達到限制時間后,處理將中斷;或(3)限制腳本代碼的文件大小、語句數(shù)量;或(4)限制臨時變量緩存的數(shù)量及大小,或者使用硬盤緩存策略;或(5)利用線程空閑及睡眠sleep控制CPU占用率;或(6)控制存在循環(huán)因素的指令函數(shù)被循環(huán)調(diào)用的次數(shù);或(7)采用虛擬機。
全文摘要
本發(fā)明涉及一種根據(jù)用戶的需求格式化輸出及操作伺服端業(yè)務數(shù)據(jù)的方法。方法如下(1)選定腳本語言及腳本語言執(zhí)行引擎;(2)用戶使用上述的語言根據(jù)業(yè)務需求編寫腳本代碼;(3)客戶端把腳本代碼發(fā)送或保存到伺服端;(4)由伺服端腳本語言執(zhí)行引擎執(zhí)行上述的腳本代碼;(5)執(zhí)行的結(jié)果數(shù)據(jù)輸出返回給客戶端。能夠?qū)崿F(xiàn)在線開發(fā),服務商拓展應用服務便捷,代碼靈活,服務商開放數(shù)據(jù)接口(API)更容易,基于該腳本語言與云計算模式,應用服務系統(tǒng)之間的數(shù)據(jù)交換、服務整合、協(xié)同應用靈活而且規(guī)范的根據(jù)用戶的需求格式化輸出及操作伺服端業(yè)務數(shù)據(jù)的方法。
文檔編號G06F9/44GK102023856SQ201010514918
公開日2011年4月20日 申請日期2010年10月21日 優(yōu)先權(quán)日2010年10月21日
發(fā)明者任浙東 申請人:杭州萬格網(wǎng)絡科技有限公司
網(wǎng)友詢問留言 已有0條留言
  • 還沒有人留言評論。精彩留言會獲得點贊!
1
拉萨市| 天水市| 南靖县| 两当县| 酉阳| 静宁县| 肥西县| 日喀则市| 油尖旺区| 乌兰县| 兴城市| 介休市| 闽侯县| 夏河县| 蓬安县| 西和县| 桐乡市| 平南县| 乐至县| 阳城县| 闻喜县| 申扎县| 宁乡县| 泌阳县| 黄冈市| 绥棱县| 肇州县| 沙坪坝区| 思南县| 青海省| 株洲县| 星子县| 长泰县| 宝兴县| 苏州市| 化德县| 太原市| 宁晋县| 大埔县| 南溪县| 阿尔山市|