分享
 
 
 

XMLHTTP和DOMDocument在WEB应用上的使用问题

王朝java/jsp·作者佚名  2006-01-09
窄屏简体版  字體: |||超大  

使用XMLHTTP可以在页面中实现无涮新自动获取服务器的新数据,

在一些聊天室中可以非常方便实现涮新新数据,同样,也可以在其它

BS应用中实现定时涮新页面数据。但在使用XMLHTTP和DOMDocument时

会碰到一些问题.一个是如何传送参数,二是中文乱码问题,还有就是如何解析XML代码。

1、参数传送和获得参数值

XMLHTTP的send方法

Send(varBody)

varBody:指令集。可以是XML格式数据,也可以是字符串,流,或者一个无符号整数数组。

也可以省略,让指令通过Open方法的URL参数代入。

send方法也可以传送参数对,各参数之间可以用&隔开,比如

var post = "id=1000&page=3";

xmlhttp.send(post);

或是在OPen方法的URL参数上加入,如

xmlhttp.open("POST", "http://localhost:8088/getData?id=1000&page=3", false);

在JSP或是Servlet中,可以和平常一样从request中得到参数

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

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

因为XMLHTTP发送的请求不是multipart/form-data格式的

因而注意在Servlet不能用multipart/form-data格式的一些方法。

2、中文乱码问题

XMLHTTP是以UTF-8编码格式发送请求和接收返回值的,因而如果不有进行编码处理,

而在发送的参数中或是接收的返回值中有中文,那么我们看到的是乱码

首先对发送的参数进行处理

var post="Years=2004-2005&TermID=秋冬"; //含有中文

xmlhttp.open("POST", "http://localhost:8088/getData", false);

xmlhttp.setRequestHeader("Content-Type","application/x-www-form-urlencoded"); //要有此句

xmlhttp.setRequestHeader("Content-Length",post.length);

xmlhttp.send(post);

在servlet里取参数时,对request进行编码处理

req.setCharacterEncoding("UTF-8");

然后取参数

String years = (String)req.getParameter("Years");

String termID = (String)req.getParameter("TermID");

如果在Servlet里有输出数据到请求的页面时,如果包含有中文,

也要进行编码处理

首先对response进行编码处理

private static final String CONTENT_TYPE = "text/html; charset=UTF-8";

res.setContentType(CONTENT_TYPE);

在输出的XML代码中用UTF-8进行编码

out.println("<?xml version=\"1.0\" encoding=\"UTF-8\" standalone=\"yes\" ?>");

out.println("<root>");

out.println("<person id=1>");

out.println("<name>张三</name>");

out.println("<gender>男</gender>");

out.println("</person>");

out.println("<book id=1>");

out.println("<bookid>11</bookid>");

out.println("<title>设计模式</title>");

out.println("</book>");

...

out.println("</root>");

3、在页面中对XML代码进行解析

全部代码如下

<script language="JavaScript">

function getNodeValue(root,NodeName)

{

try{

var node = root.selectSingleNode(NodeName);

return node.text;

}catch(e){

return "";

}

}

function getPersonNodeAttributes(XmlDoc)

{

var text = "";

var obj = XmlDoc.getElementsByTagName("person");

for (var i=0;i<obj.length;i++)

{

var node = obj.item(i);

var id=node.getAttribute("id");

var name=getNodeValue(node,"name");

var gender=getNodeValue(node,"gender");

text = "id = " + id + ",name = " + name + ",gender = " + gender;

alert(text);

}

return text;

}

function getBookNodeAttributes(XmlDoc)

{

var text = "";

var obj = XmlDoc.getElementsByTagName("book");

for (var i=0;i<obj.length;i++)

{

var node = obj.item(i);

var id=node.getAttribute("id");

var bookid=getNodeValue(node,"bookid");

var title=getNodeValue(node,"title");

text = "id = " + id + ",bookid = " + bookid + ",title = " + title;

alert(text);

}

return text;

}

//setInterval("checkResult()", 1000);//定时调用checkResult方法取新数据

function checkResult()

{

var xmlDoc = new ActiveXObject("Msxml2.DOMDocument.4.0");

xmlDoc.async = false;

var post="Years=2004-2005&TermID=秋冬";

var xmlhttp = new ActiveXObject("Msxml2.XMLHTTP.4.0");

xmlhttp.open("POST", "http://localhost:8088/getData", false);

xmlhttp.setRequestHeader("Content-Type","application/x-www-form-urlencoded");

xmlhttp.setRequestHeader("Content-Length",post.length);

xmlhttp.send(post);

xmlDoc.loadXML(xmlhttp.responseText);

var person = getBookNodeAttributes(xmlDoc);

var book = getPersonNodeAttributes(xmlDoc);

}

</SCRIPT>

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
2023年上半年GDP全球前十五强
 百态   2023-10-24
美众议院议长启动对拜登的弹劾调查
 百态   2023-09-13
上海、济南、武汉等多地出现不明坠落物
 探索   2023-09-06
印度或要将国名改为“巴拉特”
 百态   2023-09-06
男子为女友送行,买票不登机被捕
 百态   2023-08-20
手机地震预警功能怎么开?
 干货   2023-08-06
女子4年卖2套房花700多万做美容:不但没变美脸,面部还出现变形
 百态   2023-08-04
住户一楼被水淹 还冲来8头猪
 百态   2023-07-31
女子体内爬出大量瓜子状活虫
 百态   2023-07-25
地球连续35年收到神秘规律性信号,网友:不要回答!
 探索   2023-07-21
全球镓价格本周大涨27%
 探索   2023-07-09
钱都流向了那些不缺钱的人,苦都留给了能吃苦的人
 探索   2023-07-02
倩女手游刀客魅者强控制(强混乱强眩晕强睡眠)和对应控制抗性的关系
 百态   2020-08-20
美国5月9日最新疫情:美国确诊人数突破131万
 百态   2020-05-09
荷兰政府宣布将集体辞职
 干货   2020-04-30
倩女幽魂手游师徒任务情义春秋猜成语答案逍遥观:鹏程万里
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案神机营:射石饮羽
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案昆仑山:拔刀相助
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案天工阁:鬼斧神工
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案丝路古道:单枪匹马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:与虎谋皮
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:李代桃僵
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:指鹿为马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:小鸟依人
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:千金买邻
 干货   2019-11-12
 
推荐阅读
 
 
 
>>返回首頁<<
 
靜靜地坐在廢墟上,四周的荒凉一望無際,忽然覺得,淒涼也很美
© 2005- 王朝網路 版權所有