Set objXML = CreateObject("Msxml2.XMLHTTP") 或 Set objXML = CreateObject("Microsoft.XMLHTTP") 'Or for version 3.0 of XMLHTTP, use: 'Set objXML = Server.CreateObject("MSXML2.ServerXMLHTTP") |
对象创建后调用Open方法对Request对象进行初始化,语法格式为:
objXML.open http-method,url,async,userID,password |
Open方法中包含了5个参数,前三个是必要的,后两个是可选的(在服务器需要进行身份验证时提供)。参数的含义如下所示:
http-method:HTTP的通信方式,比如GET或是POST
url:接收XML数据的服务器的URL地址。通常在URL中要指明ASP或CGI程序
async:一个布尔标识,说明请求是否为异步的。如果是异步通信方式(true),客户机就不等待服务器的响应;如果是同步方式(false),客户机就要等到服务器返回消息后才去执行其他操作
userID:用户ID,用于服务器身份验证
password:用户密码,用于服务器身份验证
XMLHTTP对象的Send方法
用Open方法对Request对象进行初始化后,调用Send方法发送XML数据:
objXML.send() |
Send方法的参数类型是Variant,可以是字符串、DOM树或任意数据流。
发送数据的方式分为同步和异步两种。在异步方式下,数据包一旦发送完毕,就结束Send进程,客户机执行其他的操作;而在同步方式下,客户机要等到服务器返回确认消息后才结束Send进程。
XMLHTTP对象中的readyState属性
其能够反映出服务器在处理请求时的进展状况。客户机的程序可以根据这个状态信息设置相应的事件处理方法。属性值及其含义如下表所示:
值 说明 0 Response对象已经创建,但XML文档上载过程尚未结束 1 XML文档已经装载完毕 2 XML文档已经装载完毕,正在处理中 3 部分XML文档已经解析 4 文档已经解析完毕,客户端可以接受返回消息 |
客户机处理响应信息,客户机接收到返回消息后,进行简单的处理,基本上就完成了C/S之间的一个交互周期。
客户机接收响应是通过XMLHTTP对象的属性实现的:
responseText:将返回消息作为文本字符串;
responseBody:将返回消息作为HTML文档内容;
responseXML:将返回消息视为XML文档,在服务器响应消息中含有XML数据时使用;
responseStream:将返回消息视为Stream对象
以下是一个简单的例子:类似新闻小偷
<% Set objXML = Server.CreateObject("MSXML2.ServerXMLHTTP") objXML.open "GET","http://www.alexa.com",false objXML.send() response.write(objXML.responseText) %> |
整个步骤很明显:建立、打开、发送和接受。
p.s.本处调试为alexa站点,如果选择为国内中文站点则会出现乱码,故需要一个函数转换,具体见《 偷也是门技术——浅谈XMLHTTP应用:新闻小偷》
tages:XMLHTTP,AJAX
[Edit on 2006-1-22 11:10:57 By cnbruce]
在百度搜索完整的 转载:XMLHTTP介绍内容,或者用Google搜索 相关的更多内容
By [cnbruce] at 0:12:52 | 评论 [9] | 浏览 [20971] | TrackBack| 返回顶部 |
9 Web 2.0 :篇一上 | 下一篇: BlogAPI & XML-R... : |
About Comments |
不光是小偷程序,现在的Ajax应用XMLHttp可是派上大用场了。 |
By [宇义] at 2005-7-27 9:25:37 |
老大,你好; 在近看了xmlhttp 这个对象,也学着网上的列子,写了一个无刷新数据更新,通过客户端输入,然后添加到数据库中去。但是问题出现了,数据无法更新,也就是说数据插如不成工,sql语句是没有错误的。客户端接受响应的是类型是responseText. 但返回的时候不是我输入的信息,而是一个html的原代码,这个代码不知道什么页面的, 大致内容如:<!DOCTYPE TYPE public "--//W3c/DTD HTML 3.2 Final//EN"> <html dir =ltr> <head>...... </head><title>></title>.......这些内容 下面是我写的代码!希望得到你的指点!QQ:238901554 ------------------------------------------------------------------------------------- <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <meta http-equiv="Content-Type" content="text/html; charset=gb2312" /> <title>利用XMLHTTP无刷新添加数据</title> <script type="text/javascript"> <!-- function AddDatapost(sUserId,sUserName) { var objxmlhttp=new ActiveXObject("Microsoft.XMLHTTP"); //sUserId=escape(sUserId); //sUserName=escape(sUserName); var userinfo="userid="+sUserId+"&username="+sUserName; objxmlhttp.open("Post","http://100.100.100.168/ServerAdd.asp",false); //需要定义发送的头 objxmlhttp.setRequestHeader("Content-Length",userinfo.length) objxmlhttp.setRequestHeader("Content-Type","application/x-www-form-urlencoded") objxmlhttp.send(userinfo) //清空输入数据 document.all.userid.value=""; document.all.username.value=""; alert(objxmlhttp.responseText); } //--> </script> </head> <body> <input type="text" name="userid"><br> <input type="text" name="username"><br> <input type="button" οnclick="AddDatapost(document.all.userid.value,document.all.username.value)" value="AdddData"> </body> </html> ----------------------------------- ServerAdd.asp <%@LANGUAGE="JAVASCRIPT" CODEPAGE="936"%> <% function OpenDB(sdbname) { var connstr="Provider=Microsoft.Jet.OLEDB.4.0;Data Source="+Server.MapPath(sdbname); var conn=Server.CreateObject("ADODB.Connection"); conn.Open(connstr); return conn; } var sResult=""; var oConn=OpenDB("UserInfo.mdb"); var userid=Request.Form("userid"); var username=Request.Form("username"); sResult="userid:"+userid+"/nusername:"+username+"/n 添加成功!"; var sql="insert into Users(UserID,UserName) values('"+userid+"','"+username+"')"; oConn.Execute(sql); Response.Write(sResult); %> |
By [JimmyWang] at 2005-9-13 23:06:07 |