版权声明:转载请联系作者本人!!! https://blog.csdn.net/qq_41307491/article/details/82356745
一、发送get请求案例
<script type="text/javascript">
//创建XMLHttpRequest对象的函数
function createXMLHttpRequest() {
try {
return new XMLHttpRequest();
} catch(e) {
try {
return new ActiveXObject("Msxml2.XMLHTTP");
} catch(e) {
try {
return new ActiveXObject("Microsoft.XMLHTTP");
} catch(e) {
alert("哥们儿,你用的是什么浏览器啊?");
throw e;
}
}
}
}
window.onload = function(){ //文档加载完毕后执行的代码
var btn = document.getElementById("btn"); //得到按
btn.onclick = function(){ //给按钮的点击事件注册监听
//ajax四步操作,得到服务器响应。 把响应结果显示到h1元素中
//1.得到异步对象
var xmlHttp = createXMLHttpRequest();
//2.打开与服务器的连接
xmlHttp.open("GET", "<c:url value='/AServlet'/>", true);
//3.发送请求
xmlHttp.send(null); //GET请求没有请求体,需要给出null
//4.注册监听器
xmlHttp.onreadystatechange = function(){ //当xmlHttp的状态发生改变时执行
//双重判断:判断是否为4状态(服务器响应结束),判断是否为200(响应成功)
if(xmlHttp.readyState == 4 && xmlHttp.status == 200) {
// 获取服务器的响应内容
var text = xmlHttp.responseText;
//获取h1元素
var h1 = document.getElementById("h1");
//添加响应内容到h1元素。
h1.innerHTML = text;
}
};
};
};
</script>
</head>
<!-- 得到服务器的响应并显示 -->
<body>
<button id="btn">点击这里</button>
<h1 id="h1"></h1>
</body>
</html>
二、发送POST请求
应用:如果发送请求时需要带有参数,一般都用POST请求
1)open: 打开与服务器的连接
xmlHttp.open("POST","URL",是否异步)
2)设置Content-Type请求头:
xmlHttp.setRequestHeader("Content-Type", "application/x-www-form-urlencoded");
3)send: 发送请求时指定请求体
xmlHttp.send("username=zhangSan&password=123");
三、响应内容为xml数据案例
响应内容为xml数据
服务器端:
设置响应头:ContentType,其值为:text/xml;charset=utf-8
客户端:
var doc = xmlHttp.responseXML;//得到的是Document对象!
window.onload = function() {//文档加载完毕后执行
var btn = document.getElementById("btn");
btn.onclick = function() {//给按钮的点击事件注册监听
/*
ajax四步操作,得到服务器的响应
把响应结果显示到h1元素中
*/
/*
1. 得到异步对象
*/
var xmlHttp = createXMLHttpRequest();
/*
2. 打开与服务器的连接
* 指定请求方式
* 指定请求的URL
* 指定是否为异步请求
*/
xmlHttp.open("GET", "<c:url value='/BServlet'/>", true);
/*
3. 发送请求
*/
xmlHttp.send(null);//GET请求没有请求体,但也要给出null,不然FireFox可能会不能发送!
/*
4. 给异步对象的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;
}
};
};
};
//servlet代码
public class BServlet extends HttpServlet {
public void doGet(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
String xml = "<students>" +
"<student number='ITCAST_1001'>" +
"<name>zhangSan</name>" +
"<age>18</age>" +
"<sex>male</sex>" +
"</student>" +
"</students>";
response.setContentType("text/xml;charset=utf-8");
response.getWriter().print(xml);
}
}