zoukankan      html  css  js  c++  java
  • ajax发送异步请求

        一、ajax是什么?

    * asynchronous javascript and xml:异步的js和xml
    * 它能使用js访问服务器,而且是异步访问!
    * 服务器给客户端的响应一般是整个页面,一个html完整页面!但在ajax中因为是局部刷新,那么服务器就不用再响应整个页面!而只是数据!
      > text:纯文本
      > xml:大家都熟悉!!!
      > json:它是js提供的数据交互格式,它在ajax中最受欢迎!

    二、AJAX发送异步请求(四步操作)

    1. 第一步(得到XMLHttpRequest)
     * ajax其实只需要学习一个对象:XMLHttpRequest,如果掌握了它,就掌握了ajax!!!
     * 得到XMLHttpRequest
        > 大多数浏览器都支持:var xmlHttp = new XMLHttpRequest();
        > IE6.0:var xmlHttp = new ActiveXObject("Msxml2.XMLHTTP");
        > IE5.5以更早版本的IE:var xmlHttp = new ActiveXObject("Microsoft.XMLHTTP");

    2. 第二步(打开与服务器的连接)
      * xmlHttp.open():用来打开与服务器的连接,它需要三个参数:
      > 请求方式:可以是GET或POST
      > 请求的URL:指定服务器端资源,例如;/day23_1/AServlet
      > 请求是否为异步:如果为true表示发送异步请求,否则同步请求!
      * xmlHttp.open("GET", "/day23_1/AServlet", true);

    3. 第三步(发送请求)
      * xmlHttp.send(null):如果不给可能会造成部份浏览器无法发送!
      > 参数:就是请求体内容!如果是GET请求,必须给出null。

    4. 第四步()
      * 在xmlHttp对象的一个事件上注册监听器:onreadystatechange
      * xmlHttp对象一共有5个状态:
      > 0状态:刚创建,还没有调用open()方法;
      > 1状态:请求开始:调用了open()方法,但还没有调用send()方法
      > 2状态:调用完了send()方法了;
      > 3状态:服务器已经开始响应,但不表示响应结束了!
      > 4状态:服务器响应结束!(通常我们只关心这个状态!!!)
      * 得到xmlHttp对象的状态:
      > var state = xmlHttp.readyState;//可能是0、1、2、3、4
      * 得到服务器响应的状态码
      > var status = xmlHttp.status;//例如为200、404、500
      * 得到服务器响应的内容1
      > var content = xmlHttp.responseText;//得到服务器的响应的文本格式的内容
      > var content = xmlHttp.responseXML;//得到服务器的响应的xml响应的内容,它是Document对象了!

    三、AJAX第一例,发送get请求

    1. 创建服务器端,用于向客户端发送数据

    package ajax;
    
    import java.io.IOException;
    import javax.servlet.ServletException;
    import javax.servlet.annotation.WebServlet;
    import javax.servlet.http.HttpServlet;
    import javax.servlet.http.HttpServletRequest;
    import javax.servlet.http.HttpServletResponse;
    
    /**
     * Servlet implementation class AServlet
     */
    @WebServlet("/AServlet")
    public class AServlet extends HttpServlet {
    	
    	protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
    		System.out.println("Hello AJAX!!!");
    		response.getWriter().println("Hello AJAX");
    	}
    
    }
    

    2.  创建客户端

    <%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%>
    <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
    <html>
      <head>
        <title>My JSP 'ajax1.jsp' starting page</title>
        
    	<meta http-equiv="pragma" content="no-cache">
    	<meta http-equiv="cache-control" content="no-cache">
    	<meta http-equiv="expires" content="0">    
    	<meta http-equiv="keywords" content="keyword1,keyword2,keyword3">
    	<meta http-equiv="description" content="This is my page">
    	<!--
    	<link rel="stylesheet" type="text/css" href="styles.css">
    	-->
    <script type="text/javascript">
    // 创建异步对象
    function createXMLHttpRequest() {
    	try {
    		return new XMLHttpRequest();//大多数浏览器
    	} catch (e) {
    		try {
    			return ActvieXObject("Msxml2.XMLHTTP");//IE6.0
    		} catch (e) {
    			try {
    				return ActvieXObject("Microsoft.XMLHTTP");//IE5.5及更早版本	
    			} catch (e) {
    				alert("不支持该浏览器!");
    				throw e;
    			}
    		}
    	}
    }
    
    window.onload = function() {//文档加载完毕后执行
    	var btn = document.getElementById("btn");
    	btn.onclick = function() {//给按钮的点击事件注册监听
    		/*
    		ajax四步操作,得到服务器的响应
    		把响应结果显示到h1元素中
    		*/
    		/*
    		1. 得到异步对象 
    		*/
    		var xmlHttp = createXMLHttpRequest();
    		/*
    		2. 打开与服务器的连接
    		  * 指定请求方式
    		  * 指定请求的URL
    		  * 指定是否为异步请求
    		*/
    		xmlHttp.open("GET", "/Web04/AServlet", true);
    		/*
    		3. 发送请求
    		*/
    		xmlHttp.send(null);//GET请求没有请求体,但也要给出null,不然FireFox可能会不能发送!
    		/*
    		4. 给异步对象的onreadystatechange事件注册监听器
    		*/
    		xmlHttp.onreadystatechange = function() {//当xmlHttp的状态发生变化时执行
    			// 双重判断:xmlHttp的状态为4(服务器响应结束),以及服务器响应的状态码为200(响应成功)
    			if(xmlHttp.readyState == 4 && xmlHttp.status == 200) {
    				// 获取服务器的响应结束
    				var text = xmlHttp.responseText;
    				// 获取h1元素
    				var h1 = document.getElementById("h1");
    				h1.innerHTML = text;
    			}
    		};
    	};
    };
    </script>
      </head>
      
      <body>
    <button id="btn">点击这里</button>
    <h1 id="h1"></h1>
      </body>
    </html>
    

      

     结果展示:

    点击得到

    四、第二例,发送post请求

    服务器端

    package ajax;
    
    import java.io.IOException;
    import javax.servlet.ServletException;
    import javax.servlet.annotation.WebServlet;
    import javax.servlet.http.HttpServlet;
    import javax.servlet.http.HttpServletRequest;
    import javax.servlet.http.HttpServletResponse;
    
    /**
     * Servlet implementation class AServlet
     */
    @WebServlet("/BServlet")
    public class BServlet extends HttpServlet {
    	
    	protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
    		String name = request.getParameter("username");
    		response.getWriter().println(name);
    	}
    
    }
    

      客户端的js

    <%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%>
    
    
    <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
    <html>
      <head>
        <title>My JSP 'ajax1.jsp' starting page</title>
        
    	<meta http-equiv="pragma" content="no-cache">
    	<meta http-equiv="cache-control" content="no-cache">
    	<meta http-equiv="expires" content="0">    
    	<meta http-equiv="keywords" content="keyword1,keyword2,keyword3">
    	<meta http-equiv="description" content="This is my page">
    	<!--
    	<link rel="stylesheet" type="text/css" href="styles.css">
    	-->
    <script type="text/javascript">
    // 创建异步对象
    function createXMLHttpRequest() {
    	try {
    		return new XMLHttpRequest();//大多数浏览器
    	} catch (e) {
    		try {
    			return ActvieXObject("Msxml2.XMLHTTP");//IE6.0
    		} catch (e) {
    			try {
    				return ActvieXObject("Microsoft.XMLHTTP");//IE5.5及更早版本	
    			} catch (e) {
    				alert("不支持该浏览器!");
    				throw e;
    			}
    		}
    	}
    }
    
    window.onload = function() {//文档加载完毕后执行
    	var btn = document.getElementById("btn");
    	btn.onclick = function() {//给按钮的点击事件注册监听
    		//得到异步对象
    		var xmlHttp = createXMLHttpRequest();
    		//打开与服务器的连接
    		xmlHttp.open("POST", "/Web04/BServlet", true);
    		//设置请求头
    		xmlHttp.setRequestHeader("Content-Type", "application/x-www-form-urlencoded");
    		//发送请求
    		xmlHttp.send('username=scott&passwd=tiger');
    		/*
    		4. 给异步对象的onreadystatechange事件注册监听器
    		*/
    		xmlHttp.onreadystatechange = function() {//当xmlHttp的状态发生变化时执行
    			// 双重判断:xmlHttp的状态为4(服务器响应结束),以及服务器响应的状态码为200(响应成功)
    			if(xmlHttp.readyState == 4 && xmlHttp.status == 200) {
    				// 获取服务器的响应结束
    				var text = xmlHttp.responseText;
    				// 获取h1元素
    				var h1 = document.getElementById("h1");
    				h1.innerHTML = text;
    			}
    		};
    	};
    };
    </script>
      </head>
      
      <body>
    <button id="btn">点击这里</button>
    <h1 id="h1"></h1>
      </body>
    </html>
    

      

    五、响应内容为xml的案列

    客户端的编写

    package ajax;
    
    import java.io.IOException;
    import javax.servlet.ServletException;
    import javax.servlet.annotation.WebServlet;
    import javax.servlet.http.HttpServlet;
    import javax.servlet.http.HttpServletRequest;
    import javax.servlet.http.HttpServletResponse;
    
    /**
     * Servlet implementation class CServlet
     */
    @WebServlet("/CServlet")
    public class CServlet extends HttpServlet {
    	private static final long serialVersionUID = 1L;
    	
    	protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
    		
    		String xml = "<students>" +
    				"<student number='008'>" +
    				"<name>zhangSan</name>" +
    				"<age>18</age>" + 
    				"<sex>male</sex>" +
    				"</student>" +
    				"</students>";
    			
    			response.setContentType("text/xml;charset=utf-8");
    			response.getWriter().print(xml);
    	}
    
    
    }

    服务器端的js编写

    <%@ page language="java" contentType="text/html; charset=UTF-8"
        pageEncoding="UTF-8"%>
    <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
    <html>
    <head>
    <script type="text/javascript">
    // 创建异步对象
    function createXMLHttpRequest() {
    	try {
    		return new XMLHttpRequest();//大多数浏览器
    	} catch (e) {
    		try {
    			return ActvieXObject("Msxml2.XMLHTTP");//IE6.0
    		} catch (e) {
    			try {
    				return ActvieXObject("Microsoft.XMLHTTP");//IE5.5及更早版本	
    			} catch (e) {
    				alert("不支持该浏览器");
    				throw e;
    			}
    		}
    	}
    }
    
    window.onload = function() {//文档加载完毕后执行
    	var btn = document.getElementById("btn");
    	btn.onclick = function() {//给按钮的点击事件注册监听
    		var xmlHttp = createXMLHttpRequest();
    		//打开与服务器的连接
    		xmlHttp.open("GET", "/Web04/CServlet", true);
    		//发送请求
    		xmlHttp.send(null);//GET请求没有请求体,但也要给出null,不然FireFox可能会不能发送!
    		// 给异步对象的onreadystatechange事件注册监听器
    		xmlHttp.onreadystatechange = function() {//当xmlHttp的状态发生变化时执行
    			// 双重判断:xmlHttp的状态为4(服务器响应结束),以及服务器响应的状态码为200(响应成功)
    			if(xmlHttp.readyState == 4 && xmlHttp.status == 200) {
    				// 获取服务器的响应结果(xml)
    				var doc = xmlHttp.responseXML;
    				// 查询文档下名为student的所有元素,得到数组,再取下标0元素
    				var ele = doc.getElementsByTagName("student")[0];
    				var number = ele.getAttribute("number");//获取元素名为number的属性值
    				var name;
    				var age;
    				var sex;
    				
    				// 处理浏览器的差异
    				if(window.addEventListener) {
    					name = ele.getElementsByTagName("name")[0].textContent;//其他浏览器
    				} else {
    					name = ele.getElementsByTagName("name")[0].text;//IE支持
    				}
    				if(window.addEventListener) {
    					age = ele.getElementsByTagName("age")[0].textContent;//其他浏览器
    				} else {
    					age = ele.getElementsByTagName("age")[0].text;//IE支持
    				}
    				if(window.addEventListener) {
    					sex = ele.getElementsByTagName("sex")[0].textContent;//其他浏览器
    				} else {
    					sex = ele.getElementsByTagName("sex")[0].text;//IE支持
    				}
    
    				var text = number + ", " + name + ", " + age + ", " + sex;
    				document.getElementById("h1").innerHTML = text;
    			}
    		};
    	};
    };
    </script>
      </head>
      
      <body>
    <button id="btn">点击这里</button>
    <h1 id="h1"></h1>
      </body>
    </html>
    

      点击显示:

  • 相关阅读:
    Fiddler-代理-过滤-弱网测试
    POJ2186 Popular Cows
    POJ3264 Balanced Lineup
    多模式串字符串匹配模板题
    Intersecting Lines
    实现堆结构
    OpenJuege 兔子与星空
    拓扑排序
    POJ3635 Full Tank?
    OpenJudge Cartesian Tree
  • 原文地址:https://www.cnblogs.com/zydev/p/7355425.html
Copyright © 2011-2022 走看看