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. 创建服务器端,用于向客户端发送数据

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
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.  创建客户端

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
<%@ 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请求#

服务器端

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
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

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
<%@ 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的案列#

客户端的编写

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
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编写

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
<%@ 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>

  点击显示:

 

posted @   头痛不头痛  阅读(794)  评论(0编辑  收藏  举报
编辑推荐:
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
阅读排行:
· Manus爆火,是硬核还是营销?
· 终于写完轮子一部分:tcp代理 了,记录一下
· 别再用vector<bool>了!Google高级工程师:这可能是STL最大的设计失误
· 单元测试从入门到精通
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
历史上的今天:
2015-08-13 VNC的安装与配置
点击右上角即可分享
微信分享提示
主题色彩