Ajax技术:构建动态的Java应用程序二


下一步,设置XMLHttpRequest的头信息,以标志请求的内容为form-encoded。最后,将form-encoded数据作为请求体,并发送此请求。列表3中集中展示了这些步骤。

列表3:发送一个添加到购物车XMLHttpRequest

/*

* 通过产品编码,在购物车中添加一个条目

* itemCode – 需要添加条目的产品编码

*/

function addToCart(itemCode)

{

// 获取一个XMLHttpRequest实例

var req = newXMLHttpRequest();

// 设置用来从请求对象接收回调通知的句柄函数

var handlerFunction =

getReadyStateHandler(req, updateCart);

req.onreadystatechange =

handlerFunction;

// 打开一个联接到购物车servlet的

HTTP POST联接

// 第三个参数表示请求是异步的

req.open("POST", "cart.do", true);

// 指示请求体包含form数据

req.setRequestHeader("Content-Type",

"application/x-www-form-urlencoded");

// 发送标志需要添加到购物车

中条目的form-encoded数据

req.send("action=add&item="+itemCode);

}

结合以上内容,你可以了解到Ajax处理过程的第一部分—就是在客户端创建并发送HTTP请求。下一步是用来处理请求的Java Servlet代码。

Servlet请求处理

通过一个servlet来处理XMLHttpRequest与处理一个来自浏览器的普通的HTTP请求基本上相似。可以通过调用HttpServletRequest.getParameter()来获取由POST请求体传送过来的form-encoded数据。

Ajax请求也与普通的WEB请求样都成为此应用同一HttpSession会话进程的一部分。这对于购物车例子来说很有肜,因为我们可以通过会话将多个请求的状态都保存到同一个JavaBean购物车对象中,并可以序列化。

列表4是处理Ajax请求并更新购物车的简单servlet的代码片断。从用户会话中检索出一个Cart Bean,并按请求的参数更新它。

之后Cart Bean被序列化到XML,并被写回ServletRespone。注意,一定要将响应内容的类型设置为application/xml,否则,XMLHttpRequest将不能将响应内容解析为一个XML DOM。

列表4:处理Ajax请求的Servlet代码

public void doPost(HttpServletRequest req,

HttpServletResponse res)

throws Java.io.IOException

{

Cart cart = getCartFromSession(req);

String action = req.getParameter("action");

String item = req.getParameter("item");

if ((action != null)&&(item != null))

{

// 在购物车中添加或移除一个条目

if ("add".equals(action))

{

cart.addItem(item);

} else if ("remove".equals(action)) {

cart.removeItems(item);

}

}

// 将购物车状态序列化到XML

String cartXml = cart.toXml();

// 将XML写入response.

res.setContentType("application/xml");

res.getWriter().write(cartXml);

}


列表5展示了由Cart.toXml()方法生成的XML。注意到生成的cart元素的属性,是一个通过System.currentTimeMillis()生成的时间戳。

列表5:Cart对象序列化得到的XML


total="$171.95">

Hat

2

Chair

1

Dog

1

如果你观察一下下载站点提供的例子应用源码中的Cart.Java,你将会看到它通过简单地追加字符串来生成XML。对于本例子来说,它已经足够了,我将会在本系统文章的以后一期中介绍一些更好的方法。

现在你知道了CartServlet如何响应一个XMLHttpRequest。下一步是返回到客户端,如何用服务器响应来更新页面状态。

通过JavaScript来处理服务器响应

XMLHttpRequest的readyState属性是一个给出请求生命周期状态的数字值。它从表示“未初始化”的0变化到表示“完成”的4。每次readyState改变时,都会引发readystatechange事件,通过onreadystatechange属性配置回调处理函数将会被调用。

在列表3中,你已看到通过调用函数getReadyStateHandler()创建了一个处理函数,并被配置给onreadystatechange属性。getReadyStateHandler()使用了这样的事实:函数是JavaScript中的主要对象。

这意味着,函数可以作为参数被传递到其它函数,并且可以创建并返回其它函数。getReadystateHandler()要做是就是返回一个函数,来检查XMLHttpRequet是否已经完成处理,并传递XML服务器响应到由调用者指定的处理函数。列表6是getReadyStateHandler()的代码。

列表6:函数getReadyStateHandler()

/*

* Returns a function that waits for

the specified XMLHttpRequest

* to complete, then passes its XML

response to the given handler function.

* req - The XMLHttpRequest

whose state is changing

* responseXmlHandler -

Function to pass the XML response to

*/

function getReadyStateHandler(req,

responseXmlHandler) {

// 返回一个监听XMLHttpRequest实例的匿名函数

return function ()

{

// 如果请求的状态是“完成”

if (req.readyState == 4)

{

// 检查是否成功接收了服务器响应

if (req.status == 200)

{

// 将载有响应信息的XML传递到处理函数

responseXmlHandler(req.responseXML);

} else

{

// 有HTTP问题发生

alert("HTTP error: "+req.status);

}

}

}

}

本文作者:
« 
» 
快速导航

Copyright © 2016 phpStudy | 豫ICP备2021030365号-3