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> |
点击显示:
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 基于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的安装与配置