站长中国
设为首页 | 站长论坛

站长论坛 站长下载
您所在的位置: 站长中国 > 站长学院 > 网页设计 > 网页特效 > 正文

AJAX实践之与服务器通信(1)
  2007年11月17日04:06:47  评论(0条) 字体:[ ]
相关热点: 通信 服务器 实践 var // the xml response POST

首先看下看下相对简单些的——向服务器发送一个包含有名/值对的简单查询串,在这种情况下XHP即可以用GET也可以用POST。 GET

function doRequestUsingGET() { createXMLHttpRequest();

 var queryString = " GetAndPostExample? " ; queryString = queryString + createQueryString()+ " &timeStamp= " + new Date().getTime(); xmlHttp.onreadystatechange = handleStateChange; xmlHttp.open( " GET " , queryString, true ); xmlHttp.send( null );}

POST

function doRequestUsingPOST() { createXMLHttpRequest();

 var url = " GetAndPostExample?timeStamp= " + new Date().getTime(); var queryString = createQueryString();

 xmlHttp.open( " POST " , url, true ); xmlHttp.onreadystatechange = handleStateChange; xmlHttp.setRequestHeader( " Content-Type " , " application/x-www-form-urlencoded " );  xmlHttp.send(queryString);} 


queryString就是名/值对的参数形式了(如name=LiLin&age=23),在调用OPEN方法中,当请求方法是用POST的时候为了确保服务器知道请求体中有请求参数,需要调用setRequestHeader,将Content-Type值设置为application/x-www-form-urlencoded.当然也可不放在请求体中(那就不要用POST啦!)

此时server处理:

import java.io. * ;import java.net. * ;import javax.servlet. * ;import javax.servlet.http. * ;

public class GetAndPostExample extends HttpServlet {

 protected void processRequest(HttpServletRequest request,HttpServletResponse response, String method)throws ServletException, IOException {

// Set content type of the response to text/xml response.setContentType( " text/xml " );

// Get the user's input String firstName = request.getParameter( " firstName " );String middleName = request.getParameter( " middleName " );String birthday = request.getParameter( " birthday " );

// Create the response text String responseText = " Hello " + firstName + " " + middleName+ " . Your birthday is " + birthday + " . " + " [Method: " + method + " ] " ;

// Write the response back to the browser PrintWriter out = response.getWriter();out.println(responseText);

// Close the writer out.close(); }

 protected void doGet(HttpServletRequest request,HttpServletResponse response)throws ServletException, IOException {// Process the request in method processRequest processRequest(request, response, " GET " ); }

 protected void doPost(HttpServletRequest request, HttpServletResponse response)throws ServletException, IOException {// Process the request in method processRequest processRequest(request, response, " POST " ); } }  
对get and post方法都用processRequest来处理。
要向服务器发送相关复杂的查询串,可以将模型变化为XML发送到server 。

client端:

function createXML() { var xml = " <pets> " ;

 var options = document.getElementById( " petTypes " ).childNodes; var option = null ; for ( var i = 0 ; i < options.length; i ++ ) {option = options[i];if (option.selected) { xml = xml + " <type> " + option.value + " <\/type> " ;}  }

 xml = xml + " <\/pets> " ; return xml;}

function sendPetTypes() { createXMLHttpRequest();

 var xml = createXML(); var url = " PostingXMLExample?timeStamp= " + new Date().getTime();

 xmlHttp.open( " POST " , url, true ); xmlHttp.onreadystatechange = handleStateChange; xmlHttp.setRequestHeader( " Content-Type " , " application/x-www-form-urlencoded " );  xmlHttp.send(xml);} 

 

 

createXML方法无非就是将内容以DOM的样式存到var xml(变量)里。有时也可能出现client直接将本地的一个XML文件直接以DOM(当然可以edit)的样式传送。(也放这个时个的Content-Type应该为text/xml了!)这时可能要用到ActiveXObject("MSXML2.DOMDocument.3.0")这样一个控件了。

关于这个控件有个方法可以在各broswer中通用的JS代码:

// ------------------------------------------------ // Function: CreateXMLDOM //// Purpose: Creates a new XML DOM. //// Parameters: None //// Returns: XMLDOM object OR null // -------------------------------------------------function CreateXmlDOM(){ var oXML = new ActiveXObject(GetXmlParserProgID()); try  {oXML.setProperty( " AllowXsltScript " , true ); }  catch (err) {}

 oXML.async = false ; oXML.validateOnParse = false ; oXML.resolveExternals = false ; oXML.setProperty( " SelectionLanguage " , " XPath " ); try {oXML.setProperty( " NewParser " , true );} catch (e) {}

 return oXML;}

// -------------------------------------------------// Function: GetXmlParserProgID //// Purpose: // Gets the ProgID of the highest available version of the // Microsoft XML parser. //// Parameters: None //// Returns: String (i.e. "Msxml2.DOMDocument.4.0") //// ------------------------------------------------- function GetXmlParserProgID(){ var MAX_MAJOR_PARSER_VERSION = 10 ; var MIN_MAJOR_PARSER_VERSION = 0 ; var MAX_MINOR_PARSER_VERSION = 9 ; var MIN_MINOR_PARSER_VERSION = 0 ;

 var sProgID = g_sXmlParserProgID; var bFound = false ;

 if ( ! sProgID) {// Iterate through possible versions for ( var nMajor = MAX_MAJOR_PARSER_VERSION; nMajor >= MIN_MAJOR_PARSER_VERSION; nMajor -- ){ for ( var nMinor = MAX_MINOR_PARSER_VERSION; nMinor >= MIN_MINOR_PARSER_VERSION; nMinor -- ) {// Set up the classname for the version that we're trying to instantiate sProgID = " Msxml2.DOMDocument. " + nMajor + " . " + nMinor;

try {  if ( new ActiveXObject(sProgID))  {bFound = true ;break ; } } catch (e){}  }

 if (bFound) {// store in a global variable to speedup subsequent calls g_sXmlParserProgID = sProgID;break ; } }  }

 return sProgID;}然后直接用其load方法(本地)。

var xmlDoc = new ActiveXObject( " MSXML2.DOMDocument.3.0 " );xmlDoc.load(local_XML_FileName); 

 

 

当然也可以直接从server取来(用get方法即可),然后以responseText的方法。xmlht.Open( " GET " ,serv



收藏本文 打印 打印本文  推荐本文 告诉好友 投稿 投稿邮箱

站长排行

学院

新闻

专栏

盈利

[揭密网络黄链]中国留学生买凶专破日本
JSP语法(6)
超强弹出窗口代码,什么都挡不住
FLASH视觉特效实例之地震效果
贴吧发帖机使用教程(绝对原创)
关于数据分页(转自www.codeproject.co
ASP实现文件直接下载
Photoshop制作光感超酷效果水晶球
 遍历ASP.NET页面控件
永远的后门[经典]+查不出的后门
淘宝网卖家公然叫卖“艳照门”照片集
驳《百度Hi面世对腾讯有利》
Google绿色专家质疑黑色背景网页节省资
国内各IT企业办公环境揭秘(多图)
阿里妈妈广告卖主全攻略
站长创业源动力 主流站长站赏析
推荐阅读:80年小子的创业道理
Discuz!6.0猛将出击 最强论坛程序酷炫
我的网络,我的团队:专访李文明
百度新闻频道改版十天 流量止跌反弹翻
ECSHOP模板制作参考文档
悬挂阿里妈妈会否被百度惩罚
阿里妈妈是否是中小站长的救世主?
最强网店ECShop发新版 众多酷炫功能给
ECSHOP模板下载
土豆网,优酷网,爆米花等视频网站采集
DedeCms模板安装/制作概述
网上商店系统巅峰对决 ECShop vs ShopE
艰难的走在创业的路上 第一天
编程中国全站采集规则
性福联盟 一个不尊重站长的联盟
大脚:日赚100元—揭露最新firefox欺骗
大脚:垃圾站超级赚钱法之二—突破“站
大脚:垃圾站超级赚钱法之——前言
迅雷联盟、快车联盟收入对比
经理人必看的十个管理网站
Google Adsense的秘密 第二版
西联汇款兑付城市查询
不用SEO取得成功的10个步骤
关于做GOOGLE的五条经验
站长学院  网页设计 建站教程 图形图象 网络编程

Photoshop CS3
Photoshop CS3
不用Photoshop
不用Photoshop

DIV+CSS的开发方式 听听另外的
虚拟主机建站动易里快速生成的
VBScript特效代码 满屏幕乱跑
牛气!一个菜鸟站长的超强网站
创建、维护一个个人博客的“投
让网站流量稳步飙升的秘籍
网站推广的基本思想

新闻线索

如果你有站长界人事变动、重组并购、变革技术出现,以及产品投诉等重要新闻线索,请告诉我们,我们会给予特别关注。
0631-3653338
站长中国编辑部
站长中国24小时新闻热线: 13256307008