日韩无码专区无码一级三级片|91人人爱网站中日韩无码电影|厨房大战丰满熟妇|AV高清无码在线免费观看|另类AV日韩少妇熟女|中文日本大黄一级黄色片|色情在线视频免费|亚洲成人特黄a片|黄片wwwav色图欧美|欧亚乱色一区二区三区

RELATEED CONSULTING
相關咨詢
選擇下列產(chǎn)品馬上在線溝通
服務時間:8:30-17:00
你可能遇到了下面的問題
關閉右側工具欄

新聞中心

這里有您想知道的互聯(lián)網(wǎng)營銷解決方案
JavaFXHTTP網(wǎng)絡和XML分析

JavaFX的重點是在客戶端,目的是提高Java GUI的外觀和感覺這樣使用戶體驗更有吸引力的用戶界面。當然,許多用戶的應用程序需要用遠程服務器來交互信息。如今,HTTP協(xié)議和XML作為交互信息 的***選擇而被普遍接受,所以我們想要去展示的是在JavaFX中處理HTTP交流細節(jié)是多么簡單的事情,并且展示我們如何從一個XML數(shù)據(jù)結構中分析和提取信息的。

成都網(wǎng)站制作、成都網(wǎng)站設計、外貿營銷網(wǎng)站建設服務團隊是一支充滿著熱情的團隊,執(zhí)著、敏銳、追求更好,是創(chuàng)新互聯(lián)的標準與要求,同時竭誠為客戶提供服務是我們的理念。創(chuàng)新互聯(lián)建站把每個網(wǎng)站當做一個產(chǎn)品來開發(fā),精雕細琢,追求一名工匠心中的細致,我們更用心!

在本文中我們假設你已經(jīng)熟悉了JavaFX語言的基本概念。

JavaFX基礎語言概念

雖然是一個匯編語言,JavaFX混合了一些從Java繼承下來的腳本語言的特征。腳本語言用于快速簡潔的應用程序開發(fā),而JavaFX基于Java所繼承的特征使它成為一個更全面的語言。

JavaFX提出了一個新的編碼模式:作為一個聲明語言,它迫使我們去描述我們是多么的想要應用程序在沒有描述特定的控制流下工作的,盡管我們 用必要的語言來做這樣的事情。當我們需要開發(fā)GUI的時候這個模式是真的很強大?;镜南敕ň褪窃贘avaFX GUI開發(fā)模式的背后是你要“describe” 你的用戶界面是什么樣子的。在代碼和"visual structure."之間有嚴格的關系。此外,在代碼中,用于聲明對象的命令反應了用于展現(xiàn)他們的命令。總體的結果就是它是一個簡潔的方法用幾行的代碼 就能創(chuàng)建一個GUI。這使應用程序易于理解和維護。

另外一個JavaFX的有趣的特征就是它是一個靜態(tài)類型語言,這就意味著每個變量的數(shù)據(jù)類型,函數(shù)等等被稱為compile-time。針對這一特征的JavaFX 教程可以鏈接Resources section。

JavaFX HTTP & XML Package Overview

為了用HTTP協(xié)議和XML開發(fā)一個應用程序,JavaFX提供了一些包,如下:

· javafx.io.http for handling HTTP communication

· javafx.data.pull and javafx.data.xml for XML parsing

在Figure1中的圖解顯示了包括這些包的分類:

HTTP &JavaFX

處理HTTP協(xié)議時,我們在javafx.io.http 包中可以使用HttpRequest 類別。這個類別可以使異步HTTP請求到達支持HTTP協(xié)議的一臺遠程服務器中。目前支持HTTP方法有:

· GET

· POST

· PUT

· DELETE

這個類別在數(shù)據(jù)交換中是保持中立的,所以我們可以調用一臺遠程服務器并且發(fā)送我們想要發(fā)送的任何信息類型,只要我們可以提供一個OutputStream其中包括必須用POST 或是PUT HTTP方法發(fā)送的數(shù)據(jù)。

與每一個HTTP支持方法有關的HttpRequest操作有特定的循環(huán)周期。就HTTP GET 方法來說,我們關注在的是循環(huán)周期。對于其他的方法(POST, PUT, DELETE),循環(huán)周期是相同的。如果是HTTP GET 請求,循環(huán)周期如Figure 2所示:

Figure 2: HTTP GET method request lifecycle

正如以上我們所看到的,每一塊循環(huán)周期的描述都被HttpRequest class的內部變量的特定值所定義。

關于每個變量的轉換,有一個相應的方法叫做during the transition itself,這樣我們能夠控制和處理不同的在HTTP 循環(huán)周期的狀態(tài)。這些方法都有相應變量的相同的名字,前綴用on。例如,我們想在請求連接到服務器時來追蹤,就使用onConnecting函數(shù)。

是時候為我們的JavaFX客戶端進行編碼了。首先我們必須聲明一個包括URL的變量:

def url : String = "http://www.java.net";

然后創(chuàng)建HTTP請求并且規(guī)定callback函數(shù),當HTTP請求開始連接的時候可以呼叫。

HttpRequest { location: url;

onConnecting: function() {

java.lang.System.out.println("Connecting");

}

}.enqueue();

注意生成這個請求的方法enqueue()。 現(xiàn)在我們想要讀取反應部分。我們可以使用onInput 功能提供的InputStream。我們需要添加這條代碼到客戶端。

onInput: function(is: InputStream) { try {

var responseSize : Integer = is.available();

java.lang.System.out.println("Response size {responseSize}");

}

finally {

is.close();

}

}

***一步是處理在HTTP請求期間發(fā)生的任何的異常情況。HTTPRequest有一個功能叫做無論何時所發(fā)生的異常(whenever an exception occurs)。所以我們可以為客戶端添加異常處理的代碼。

onException: function(ex : Exception) { System.out.println("Error: {ex.getMessage()}");

}

如果用NetBeans運行客戶端,你可以看到類似Figure 3的輸出:

Figure 3: Client log

在javafx.io.http包,中,有其他兩個類別叫HttpHeaders 和 HttpStatus。***個類別定義一組常量對應相應的HTTP header 值名字。第二個類別定義一組常量對應可能的HTTP 反應代碼。

#p#

XML API

正如我們所說的,今天很多客戶端用一個XML模板來發(fā)送數(shù)據(jù)到HTTP, 而且JavaFX提供了簡單解析XML文件的能力。現(xiàn)在我們關注其他兩個包,在Figure1中所示:

· javafx.data.xml

· javafx.data.pull

javafx.data.pull包含了分析一個XML文件的類別,同時javafx.data.xml 包 定義了一些常量并且處理合格的名稱。處理器是event-based(類似SAX parser)并且支持兩個不同的數(shù)據(jù)格式:

· XML

· JSON

本文我們關注在XML數(shù)據(jù)格式。

PullParser class是JavaFX的文件分析器的核心,可以接受用于控制分析器的許多屬性。首先,我們需要聲明一個我們想要分析的文件類型,使用類別屬性documentType。該字符串有兩個值:

· PullParser.XML 用于分析XML

· PullParser.JSON 用于分析JSON

在聲明文件類型之后,我們需要提供文件輸入去分析。分析器接受一個輸入流,以后我們會看到,這是非常方便的當我們需要去分析一個來自HTTP 請求的XML文件。為了聲明輸入流我們需要設置input變量的值。

所以來創(chuàng)建一個PullParser的例子,如下:

parser = PullParser { documentType: PullParser.XML;

input: xmlFileInputStream;

}

當分析器分析文件的時候,它會產(chǎn)生一系列的條目。我們需要執(zhí)行一個callback函數(shù)來應對這些條目的發(fā)生。這個callback 函數(shù)叫做onEvent,而其在它本身中,稍后我們會執(zhí)行我們的邏輯來從文件中提取信息。 函數(shù)簽名是onEvent(event : Event),Event類別屬于javafx.data.pull包。這個類別包括所有關于pull-parsing條目,而且可以用它來提取我們需要的信息。作為在PullParser 定義中的值之一,Type 聲明了條目的類型,我們感興趣于一下類型的條目:

· START_DOCUMENT: 這個條目在文件分析的開始時產(chǎn)生的。

· START_ELEMENT: 這個條目是在分析器找到新的開始元素時產(chǎn)生的。我們可以用這個條目來讀取元素屬性。

· END_ELEMENT: 這個條目是在分析器找到***的元素時產(chǎn)生的。我們可以用它來讀取元素中的文本。

· END_DOCUMENT: 這個條目是在分析器到達***的文件時產(chǎn)生的。

還有其他的條目用于JSON 文件;如果你感興趣,可以看一看PullParser文件。無論如何,這里有針對START_ELEMENT 和END_ELEMENT 條目反應的一個框架實施:

onEvent: function(event : Event) { /* We start analyzing the different event types */

if (event.type == PullParser.START_ELEMENT) {

/* Here we implement our logic to handle the start element event,

for example to extract the attribute values and so on */

}

else if (event.type == PullParser.END_ELEMENT) {

/* Here we implement our logic to handle the end element */

}

}

在分析過程中,一些錯誤也會產(chǎn)生。我們可以管理他們只要檢查了被分析器所產(chǎn)生的條目類型。 整合 HTTP & XML APIs

現(xiàn)在我們已經(jīng)描述了這兩個API, 該看一下最有趣的部分了: 我們怎樣去整合所有的東西這樣我們才能編譯一個完整的XML-over-HTTP的客戶端。這是非常有用的如果我們想要一個客戶端來用遠程服務器交互信息。

讓我們假設JavaFX客戶端應用程序調用一個可以恢復XML文件的serlet結構如下:

﹤?xml version="1.0" encoding="UTF-8"?﹥
﹤data﹥
﹤person id="1"﹥
﹤name﹥Mikey﹤/name﹥
﹤surname﹥Mouse﹤/surname﹥
﹤/person﹥
﹤/data﹥

這個一個簡單的XML文件,但是足夠達到示例的目的了。我們的目標是為我們的客戶端連接到test serlet并且檢索XML內容,然后分析它并且顯示提取的信息。為了做到這一點,我們需要改變HttpRequest函數(shù)onInput為了當我們開始 接收XML文件時也可以去分析它。如何操作的代碼如下所示:

onInput: function(is: InputStream) { try {

PullParser {

input: is;

onEvent: function (event : Event) {

// We handle the event

}

}.parse();

}

finally {

is.close();

}

}

注意我們怎樣添加了PullParser到onInput函數(shù),而且我們設置了分析器輸入流到從HttpRequest接收的輸入流?,F(xiàn)在我們只需要處理以上所描述的條目:

.... if (event.type == PullParser.START_ELEMENT and event.level == 1) {

java.lang.System.out.println("Start a new element {event.qname.name}");

var qAttr : QName = QName {name : "id"};

var attVal : String = event.getAttributeValue(qAttr);

java.lang.System.out.println("Attribute ID value {attVal}");

}

else if (event.type == PullParser.END_ELEMENT) {

var nodeName : String = event.qname.name;

java.lang.System.out.println("End element {nodeName}");

// Now we extract the text only if the node is name or surname

if (nodeName == "name" or nodeName == "surname") {

var textVal : String = event.text;

java.lang.System.out.println("Text {textVal}");

}

}

....

一步步分析代碼是非常有用的。在有PullParser.START_ELEMENT條目的情況下,我們使用event.level變量。這個 告訴我們每個條目是在哪一個行發(fā)生的(從0開始,XML文件的根源)。我們已經(jīng)知道id屬性是在***行,所以我們只在這一行限制提取。然后創(chuàng)建一個 QName目標設置,名稱變化是根據(jù)屬性名稱,然后我們應用該值。

在PullParser.END_ELEMENT情況下,我們想要提取節(jié)點內容。為了做到這一點,我們使用包括節(jié)點值的text變量。

如果一切運行正常,我們將會在項目控制臺(console)中看到所分析的條目,如Figure 4.所示:

Figure 4. HTTP request with XML parsing

結束語

在本文中,我們探討了一些JavaFX的基本特點,主要集中在兩個重要的方面:XML and HTTP。我們發(fā)現(xiàn)開發(fā)一個HTTP 請求和XML反應的客戶端是多么簡單的事情。這是個簡單的例子,但是通過添加其他特征可以進行延展,例如,連接一個站點或是檢索圖片。


當前題目:JavaFXHTTP網(wǎng)絡和XML分析
當前路徑:http://m.5511xx.com/article/cdjidei.html