`
cakin24
  • 浏览: 1367784 次
  • 性别: Icon_minigender_1
  • 来自: 西安
社区版块
存档分类
最新评论

与服务器通信——发送请求与处理响应

阅读更多
一 发送请求
Ajax可以通过XMLHttpRequest对象实现采用异步方式在后台发送请求。
通常情况下,Ajax发送请求有两种,一种是发送GET请求,另一种是发送POST请求。
但是无论发送哪种请求,都需要经过以下4个步骤。
1、初始化XMLHttpRequest对象。
为了提高程序的兼容性,需要创建一个跨浏览器的XMLHttpRequest对象,并且判断XMLHttpRequest对象的实例是否成功,如果不成功,则给予提示。
具体代码如下: 
http_request = false;
if (window.XMLHttpRequest) // 非IE浏览器
{                                                     
	http_request = new XMLHttpRequest();   //创建XMLHttpRequest对象
} 
else if (window.ActiveXObject)   // IE浏览器
{                                               
	try 
	{
		http_request = new ActiveXObject("Msxml2.XMLHTTP");   //创建XMLHttpRequest对象
    } 
    catch (e) 
    {
    	try 
    	{
        	http_request = new ActiveXObject("Microsoft.XMLHTTP");  //创建XMLHttpRequest对象
        } 
        catch (e) 
        {
        }
	}
}
if (!http_request) 
{
	alert("不能创建XMLHttpRequest对象实例!");
    return false;
}
 
2、为XMLHttpRequest对象指定一个返回结果处理函数(即回调函数),用于对返回结果进行处理。
具体代码如下: 
http_request.onreadystatechange = getResult;   //调用返回结果处理函数
使用XMLHttpRequest对象的onreadystatechange属性指定回调函数时,不能指定要传递的参数。
如果要指定传递的参数,可以应用以下方法:
http_request.onreadystatechange = function(){getResult(param)};
3、创建一个与服务器的连接。
在创建时,需要指定发送请求的方式(即GET或POST),以及设置是否采用异步方式发送请求。
例如,采用异步方式发送GET方式的请求的具体代码如下: 
http_request.open('GET', url, true);
例如,采用异步方式发送POST方式的请求的具体代码如下:
http_request.open('POST', url, true);
在open()方法中的url参数,可以是一个JSP页面的URL地址,也可以是Servlet的映射地址。
也就是说,请求处理页,可以是一个JSP页面,也可以是一个Servlet。
在指定URL参数时,最好将一个时间戳追加到该URL参数的后面,这样可以防止因浏览器缓存而不能实时得到最新的结果。
例如,可以指定URL参数为以下代码。
String url="deal.jsp?nocache="+new Date().getTime();
4、向服务器发送请求。
XMLHttpRequest对象的send()方法可以实现向服务器发送请求,该方法需要传递一个参数,如果发送的是GET请求,可以将该参数设置为null,如果发送的是POST请求,可以通过该参数指定要发送的请求参数。
向服务器发送GET请求的代码如下:
http_request.send(null);    //向服务器发送请求
向服务器发送POST请求的代码如下:
var param="user="+form1.user.value+"&pwd="+form1.pwd.value+"&email="+form1.email.value; //组合参数
http_request.send(param);     //向服务器发送请求
需要注意的是:在发送POST请求前,还需要设置正确的请求头,具体代码如下:
if(method=="POST")  // 如果提交方式为POST
{                                                                                
http_request.setRequestHeader("Content-Type","application/x-www-form-urlencoded");  //设置请求的内容类型
http_request.setRequestHeader("x-requested-with", "ajax");     //设置请求的发出者
}
上面的这句代码,需要添加在http_request.send(param);语句之前。
 
二 处理服务器响应
当向服务器发送请求后,接下来就需要处理服务器响应了。
在向服务器发送请求时,需要通过XMLHttpRequest对象的onreadystatechange属性指定一个回调函数,用于处理服务器响应。
在这个回调函数中,首先需要判断服务器的请求状态,保证请求已完成,然后再根据服务器的HTTP状态码,判断服务器对请求的响应是否成功,如果成功,则获取服务器的响应,并反馈给客户端。
XMLHttpRequest对象提供了两个用来访问服务器响应的属性,一个是responseText属性,返回字符串响应,另一个是responseXML属性,返回XML响应。
下面分别进行介绍。
1、处理字符串响应
字符串响应通常应用在响应不是特别复杂的情况下。
例如,将响应显示在提示对话框中,或者响应只是显示成功或失败的字符串。
将字符串响应显示到提示对话框中的回调函数的具体代码如下: 
function getResult() 
{
	if (http_request.readyState == 4) // 判断请求状态
	{                        
		if (http_request.status == 200) // 请求成功,开始处理返回结果
		{             
        	alert(http_request.responseText);         // 显示判断结果
        } 
        else // 请求页面有错误
        {                                                 
            alert("您所请求的页面有错误!");
        }
    }
}
 
如果需要将响应结果显示到页面的指定位置,也可以先在页面的合适位置添加一个<div>或<span>标记,并设置该标记的id属性,例如div_result,然后在回调函数中应用以下代码显示响应结果。
document.getElementById("div_result").innerHTML=http_request.responseText;
2.处理XML响应
如果在服务器端需要生成特别复杂的响应,那么就需要应用XML响应。
应用XMLHttpRequest对象的responseXML属性,可以生成一个XML文档,而且当前浏览器已经提供了很好的解析XML文档对象的方法。
例如,有一个保存图书信息的XML文档,具体代码如下:
<?xml version="1.0" encoding="UTF-8"?>
<ms>
      <books>
            <book>
                  <title>Java Web开发典型模块大全</title>
                  <publisher>人民邮电出版社</publisher>
            </book>
            <book>
                  <title>Java范例完全自学手册</title>
                  <publisher>人民邮电出版社</publisher>
            </book>
      </books>
</ms>
 
在回调函数中遍历保存图书信息的XML文档,并显示到页面中的代码如下:
function getResult() 
{
    if (http_request.readyState == 4) //判断请求状态
    {                                             
        if (http_request.status == 200) //请求成功,开始处理响应
        {                                  
        	var xmldoc = http_request.responseXML;
            var str="";
            for(i=0;i<xmldoc.getElementsByTagName("book").length;i++)
            {
            	var book = xmldoc.getElementsByTagName("book").item(i);
                str=str+"《"+book.getElementsByTagName("title")[0].firstChild.data+"》由“"+
                book.getElementsByTagName('publisher')[0].firstChild.data+"”出版<br>";
            }
            document.getElementById("book").innerHTML=str;             //显示图书信息
        } 
        else 	//请求页面有错误
        {                                                               
            alert("您所请求的页面有错误!");
        }
    }
}
<div id="book"></div>
 
通过上面的代码获取的XML文档的信息如下:
《Java Web开发典型模块大全》由“人民邮电出版社”出版
《Java范例完全自学手册》由“人民邮电出版社”出版
1
0
分享到:
评论

相关推荐

    初识通信——多线程服务器的建立

    每个线程通常包含读取客户端数据、处理数据、然后向客户端发送响应的过程。 4. **关闭资源**:处理完客户端请求后,记得关闭`Socket`和相关流,以释放系统资源。 在实现过程中,我们可能会遇到数据同步的问题。...

    通信基础——实现服务器与客户端的交流

    标题“通信基础——实现服务器与客户端的交流”揭示了本文将深入探讨网络通信的基本原理,特别是涉及服务器和客户端之间的互动。在IT行业中,这种交互是网络应用的核心,无论是网页浏览、电子邮件、在线游戏还是文件...

    TCP通信——本机发送接收

    客户端方面,使用TcpClient与服务器建立连接。我们调用Connect()方法,传入服务器的IP地址和端口号。同样,通过GetStream()方法获取网络流,实现数据的发送和接收。C#的StreamReader和StreamWriter类可以方便地处理...

    使用MFC套接字CAsyncSocket进行网络通信——服务器端

    总的来说,CAsyncSocket使得MFC应用程序能够轻松地实现网络通信功能,而服务器端的应用则需要有效地管理多个并发连接,处理客户端的请求并发送响应。通过学习和实践这个例子,你将能够掌握如何在MFC环境中利用...

    tomcat 分配请求之——socket获取请求

    标题“Tomcat分配请求之——Socket获取请求”主要涉及的是Tomcat服务器在处理HTTP请求时的核心机制。在Web服务器中,Tomcat是一个广泛使用的开源应用服务器,它负责解析并响应来自客户端(如浏览器)的HTTP请求。这...

    11.4.4 通信缓慢——服务器延迟 - Wireshark 数据包分析实战(第 3 版) - 知乎书店1

    在Wireshark数据包分析实战第三版中,我们聚焦于一个特定的问题——11.4.4章节讨论的“通信缓慢——服务器延迟”。这个场景通过分析一个名为"latency4.pcap"的网络捕获文件来展示。在图11-25中,我们看到在服务器...

    基于java的局域网通信——飞鸽传书源代码.zip

    这样,即使有多个客户端同时请求,服务器也能有效地处理每个请求,不会因为等待一个客户端的响应而阻塞其他客户端。 5. **异常处理**:在网络编程中,由于网络环境的不可预测性,异常处理非常重要。开发者需要捕获...

    11.4.2 慢速通信——线路延迟 - Wireshark 数据包分析实战(第 3 版) - 知乎书店1

    慢速通信——线路延迟 Wireshark 数据包分析实战(第 3 版)中讲解了慢速通信的线路延迟问题。在本节中,我们将学习如何使用 Wireshark 分析数据包来识别线路延迟,并了解其可能的原因。 线路延迟是指在网络通信...

    7、使用JSON向服务器发送数据——ajax基础笔记

    6. 监听状态变化:通过`onreadystatechange`事件监听请求的状态,当状态变为4(表示请求已完成)且状态码为200(表示成功)时,可以处理响应数据。 ```javascript xhr.onreadystatechange = function() { if ...

    iOS基础——网络请求之NSURLConnection、NSURLSessionDataTask

    在iOS开发中,网络请求是应用与服务器交互的重要方式,主要涉及两个主要的API:NSURLConnection和NSURLSessionDataTask。这两个类都是Apple的Foundation框架提供,用于处理HTTP和其他Web服务的通信。接下来,我们将...

    并发服务器II——多线程

    在多线程网络服务器模型中,通常采用一种称为"线程池"的策略,预先创建一定数量的线程,用于处理客户端请求。当有新的连接请求时,服务器不会每次都创建新的线程,而是从线程池中选取一个空闲线程进行服务,从而减少...

    通信协议——Http、TCP、UDP

    - 服务器接收到请求后处理并返回HTTP响应。 - 客户端解析响应内容并展示给用户。 - **请求消息结构**: - 第一行:请求行,包含请求方法(GET、POST等)、请求的资源路径和HTTP版本。 - 后续行:请求头,包含了...

    Android源码——与php服务器交互实例源码_new_25.zip

    总之,这个实例提供了Android客户端与PHP服务器交互的完整流程,从发起请求、处理响应到错误处理和数据格式化,涵盖了网络通信的关键环节。通过研究这些代码,开发者可以加深对Android网络编程的理解,提高自己的...

    通信协议——HTTP、TCP、UDP

    HTTP 协议的工作流程是:浏览器向 Web 服务器发送请求,Web 服务器接收到请求后,进行处理,然后将结果返回给浏览器。浏览器接收到结果后,将其显示出来。 TCP 协议是传输层协议,它提供了可靠的、面向连接的传输...

    vue第四天笔记02——axios请求中的例子

    在实际项目中,我们可以根据需求灵活运用axios,实现与后端的高效通信。 总之,Vue项目中使用axios进行API请求是非常常见的操作。通过axios,我们可以轻松地发送HTTP请求,获取服务器数据,进而实现各种复杂的业务...

    公共自行车管理系统服务器端——毕业设计

    2. **RESTful API设计**:为了使客户端能够与服务器通信,通常会设计一套RESTful API。REST(Representational State Transfer)是一种网络应用程序的设计风格和开发方式,基于HTTP协议,以JSON或XML格式交换数据。...

    安卓Android源码——与asp.net中的一般处理程序ashx进行交互.zip

    总结一下,这个压缩包提供的源码示例展示了如何在Android客户端使用HttpURLConnection与ASP.NET服务器上的ASHX处理程序进行通信,包括发送请求、解析JSON响应以及使用Handler更新UI。这是一个典型的移动应用与后端...

    JSP源码——动态显示JSP服务器内存的Ajax程序 图像版_systemjc.zip

    5. JavaScript/Ajax代码:主要负责与服务器通信,发送请求,处理响应,并更新图表。这通常涉及到XMLHttpRequest对象或现代浏览器提供的fetch API。 通过这个项目,开发者可以了解到如何集成JSP、Ajax以及数据可视化...

    安卓Android源码——android与asp.net中的一般处理程序ashx进行交互.zip

    当Android应用需要与远程服务器通信时,可以采用HTTP或HTTPS协议,通过发送网络请求获取或发送数据。在这种情况下,服务器端使用的是ASP.NET,这是一个由Microsoft开发的Web应用程序框架,它允许开发者创建动态、...

    手机安全卫士(3)——获取服务器更新配置

    本节我们将探讨“手机安全卫士(3)——获取服务器更新配置”这一主题,这涉及到应用如何通过网络与远程服务器进行通信,以获取最新的安全策略和更新数据。 首先,我们需要理解的是Android应用程序如何进行网络通信...

Global site tag (gtag.js) - Google Analytics