打开APP
userphoto
未登录

开通VIP,畅享免费电子书等14项超值服

开通VIP
xmlhttp初体验

太久没有研究过新技术了.作为一个程序员,我觉得很惭愧.老早就想看看关于xmlhttp的技术了,今天总算有点时间,做个一个最初的体验.马上就爱上了它.
如果你想不刷新页面就可以与后台进行数据交互,或者在异构系统之间交换数据,xmlhttp技术是个不错的选择.
下面是我的一个很小的体验程序,参考了csdn网友s_phoenix()给人的回贴.
首先建一个tomcat的web项目.

1:-------index.htm文件内容如下:

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0Transitional//EN">
<HTML>
<HEAD>
<TITLE> NewDocument </TITLE>
<META NAME="Generator"CONTENT="EditPlus">
<META NAME="Author" CONTENT="">
<METANAME="Keywords" CONTENT="">
<META NAME="Description"CONTENT="">
</HEAD>

<BODY>
<script language="javascript">
varXML="<root><test>李春雷</test><test>毛泽东</test></root>"
varxmlHttp = new ActiveXObject("Msxml2.XMLHTTP");
var xmlDoc=newActiveXObject("Msxml2.DOMDocument");
functiontest(){//客户端xml的解析
xmlDoc.loadXML(XML);
if(xmlDoc.parseError.line>0){
throwxmlDoc.parseError.reason;
}
var nodes=xmlDoc.selectNodes("/root/test");
for(vari=0;i<nodes.length;i++){
alert(nodes.item(i).text);
}
}

functionaction(){//客户端和服务端的通讯
xmlHttp.open("post","http://127.0.0.1:8888/xmlhttpTest/UrlTestServlet",false);
xmlHttp.setRequestHeader("context-type","text/xml;charset=utf-8");
xmlHttp.send(XML);
varshowstr=xmlHttp.responseText;
alert(showstr);
}

</script>
<buttononclick="test();">查看将要传输的xml</button><br/>
<buttononclick="action();">朝服务器传送xml,并接收服务器回应</button>
</BODY>
</HTML>


2:------------写一个servlet: UrlTestServlet.java

/*
 * 创建日期 2005-4-7
 *
 * TODO 要更改此生成的文件的模板,请转至
 * 窗口 - 首选项 -Java - 代码样式 - 代码模板
 */
package com.lcl;

import javax.servlet.*;
import javax.servlet.http.*;
importjava.io.*;
import java.util.*;
import org.dom4j.io.*;
importorg.dom4j.*;


/**
 * @author lcl
 *
 * TODO 要更改此生成的类型注释的模板,请转至
 * 窗口 - 首选项- Java - 代码样式 - 代码模板
 */

public -8";
//Initialize global variables
public void init() throwsServletException {
}
//Process the HTTP Get request


public void doGet(HttpServletRequest request, HttpServletResponseresponse)
throws ServletException, IOException{
response.setContentType(CONTENT_TYPE);
request.setCharacterEncoding("utf-8");
PrintWriterout = response.getWriter();
InputStream is=request.getInputStream();

SAXReader reader=new SAXReader();
Documentdoc=null;
try{
doc=reader.read(is);
} catch(Exceptionex){
System.out.println(ex);
}
String[] s=getElementTexts(doc,"test");
out.println("数据交换成功:返回" + s[0] + s[1]);
}

public void doPost(HttpServletRequest request, HttpServletResponse response)throws ServletException, IOException {
doGet(request,response);
}

private String getElementText(Document doc,String name){
returndoc.getRootElement().element(name).getText();
}

private String[] getElementTexts(Document doc,String name){
Listl=doc.getRootElement().elements(name);
Iterator it=l.iterator();
Listl1=new LinkedList();
while(it.hasNext()){
Elemente=(Element)it.next();
l1.add(e.getText());
}
return(String[])l1.toArray(new String[]{});
}

//Clean up resources
public void destroy() {
}
}

3:--------web.xml更改如下(加servlet映射):

<?xml version="1.0" encoding="ISO-8859-1"?>

<!DOCTYPE web-app
    PUBLIC "-//Sun Microsystems, Inc.//DTD WebApplication 2.3//EN"
   "http://java.sun.com/dtd/web-app_2_3.dtd">

<web-app>
  <display-name>Welcome toTomcat</display-name>
  <description>
     Welcome toTomcat
  </description>


<!-- JSPC servlet mappings start -->

    <servlet>
       <servlet-name>UrlTestServlet</servlet-name>
       <servlet-class>com.lcl.UrlTestServlet</servlet-class>
   </servlet>
 

    <servlet-mapping>
       <servlet-name>UrlTestServlet</servlet-name>
       <url-pattern>/UrlTestServlet</url-pattern>
   </servlet-mapping>


<!-- JSPC servlet mappings end-->
 <welcome-file-list>
       <welcome-file>index.htm</welcome-file>
   </welcome-file-list>
</web-app>

好了,启动tomcat,访问:http://127.0.0.1:8888/xmlhttpTest/work/(如果你的tomcat端口是8080,就改一下)
看到结果了吧,真的很不错.不用刷新页面,就让htm前台页面和后台进行了一次数据交换.

你甚至可以在不同的服务器之间进行数据交换,比如一个mis系统,和一个gis系统,想整合成一个系统,原先我们是用了一个frame,左边的是mis,右边的是gis,通过javascript在两个系统间交换数据.如果用xmlhttp技术,完全没必要这样了.

本站仅提供存储服务,所有内容均由用户发布,如发现有害或侵权内容,请点击举报
打开APP,阅读全文并永久保存 查看更多类似文章
猜你喜欢
类似文章
【热】打开小程序,算一算2024你的财运
string 转化xml xml转化为string
xml解析器
XML DOM
Dom4j 学习笔记
Dom4j节点处理器的实现
在spring mvc框架中显示xml视图
更多类似文章 >>
生活服务
热点新闻
分享 收藏 导长图 关注 下载文章
绑定账号成功
后续可登录账号畅享VIP特权!
如果VIP功能使用有故障,
可点击这里联系客服!

联系客服