首先理解以下概念:
同步交互和异步交互:
举个例子:普通B/S模式(同步) AJAX技术(异步)
* 同步:提交请求->等待服务器处理->处理完毕返回 这个期间客户端浏览器不能干任何事
* 异步: 请求通过事件触发->服务器处理(这时浏览器仍然可以作其他事情)->处理完毕
同步是指:发送方发出数据后,等接收方发回响应以后才发下一个
数据包的通讯方式。
异步是指:发送方发出数据后,不等接收方发回响应,接着发送下
个数据包的通讯方式 。
易懂的理解:
异步传输: 你传输吧,我去做我的事了,传输完了告诉我一声 同步传输: 你现在传输,我要亲眼看你传输完成,才去做别的事
function createXmlHttpRequest(){
var xmlHttp;
try{
//Firefox, Opera 8.0+, Safari
xmlHttp=new XMLHttpRequest();
}catch (e){
try{
//Internet Explorer
xmlHttp=new ActiveXObject("Msxml2.XMLHTTP");
}catch (e){
try{
xmlHttp=new ActiveXObject("Microsoft.XMLHTTP");
}catch(e){
}
}
}
return xmlHttp;
}
<%@ page language="java" pageEncoding="utf-8"%>
test.js
//创建一个XMLHttpRequest对象,利用此对象域服务器进行通信 是AJAX技术的核心
function ajaxFunction(){
var xmlHttp;
try{
// Firefox, Opera 8.0+, Safari
xmlHttp = new XMLHttpRequest();
}catch(e){
try{
//Internet Explorer
xmlHttp = new ActiveXObject("Msxml2.XMLHTTP");
}catch(e){
try {
xmlHttp = new ActiveXObject("Microsoft.XMLHTTP");
}
catch (e) {
}
}
}
return xmlHttp;
}
window.onload = function(){
document.getElementById("ok").onclick = function(){
//1.创建ajax引擎
var xmlHttp = ajaxFunction();
//2.接收服务器端响应的结果
/**
* onreadystatechange:
* * 该事件处理函数由服务器触发,而不是用户
* * 在 Ajax 执行过程中,服务器会通知客户端当前的通信状态。
* 这依靠更新 XMLHttpRequest 对象的 readyState 来实现。改变 readyState 属性是服务器对客户端连接操作的一种方式。
每次 readyState 属性的改变都会触发 readystatechange事件
* readyState:
* readyState 属性表示Ajax请求的当前状态。它的值用数字代表。
0 代表未初始化。 还没有调用 open 方法
1 代表正在加载。 open 方法已被调用,但 send 方法还没有被调用
2 代表已加载完毕。send 已被调用。请求已经开始
3 代表交互中。服务器正在发送响应
4 代表完成。响应发送完毕
* status:
* status 服务器发送的每一个响应也都带有首部信息。
* 三位数的状态码是服务器发送的响应中最重要的首部信息,并且属于超文本传输协议中的一部分。
常用状态码及其含义:
404 没找到页面(not found)
403 禁止访问(forbidden)
500 内部服务器出错(internal service error)
200 一切正常(ok)
304 没有被修改(not modified)(服务器返回304状态,表示源文件没有被修改 )
* 接收服务器的响应结果
* * responseText:XMLHttpRequest 的 responseText 属性包含了从服务器发送的数据。
* 它是一个HTML,XML或普通文本,这取决于服务器发送的内容。
* * responseXML:如果服务器返回的是 XML, 那么数据将储存在 responseXML 属性中。
*
*/
xmlHttp.onreadystatechange = function(){
alert(xmlHttp.readyState);
if(xmlHttp.readyState == 4){
alert(xmlHttp.readyState);
if(xmlHttp.status == 200 || xmlHttp.status == 304){
var data = xmlHttp.responseText;
alert(data);
}
}
}
//3.打开一个链接
/**
* open(method, url, asynch)
* method:请求类型,类似 “GET”或”POST”的字符串
* url:路径字符串,指向你所请求的服务器上的那个文件。可以是绝对路径或相对路径。
* asynch:表示请求是否要异步传输,默认值为true(异步)
*/
xmlHttp.open("GET","../testServlet?a=8×tamp="+new Date().getTime(),true);
//4.发送请求数据
/**
* send(data):
* * data:将要传递给服务器的字符串
* * 若选用的是 GET 请求,则不会发送任何数据, 给 send 方法传递 null 即可
* * 需要传值的时候,可以定义a=8&b=9
* * 使用get请求时send方法参数时null,如果传值的话,服务器也接受不到
*/
xmlHttp.send(null);
}
}
TestServlet.java
package cn.itcast.servlet;
import java.io.IOException;
import java.io.PrintWriter;
import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
@WebServlet("/testServlet")
public class TestServlet extends HttpServlet {
public void doGet(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
request.setCharacterEncoding("UTF-8");
response.setContentType("text/html;charset=utf-8");
PrintWriter out = response.getWriter();
System.out.println("访问服务器成功!调用的方法是doGet");
System.out.println("method:"+request.getMethod());
System.out.println("URL:"+request.getRequestURL());
System.out.println("queryString:"+request.getQueryString());
System.out.println("a:"+request.getParameter("a"));
System.out.println("b:"+request.getParameter("b"));
System.out.println("c:"+request.getParameter("c"));
//将服务器的处理的内容响应到客户端
out.println("发回响应数据,当前请求是:"+request.getMethod());
out.flush();
out.close();
}
public void doPost(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
}
}
将应用部署到tomcat服务器上,并访问:http://localhost:8080/itcast0701Ajax/testget/testget.jsp
<%@ page language="java" pageEncoding="utf-8"%>
test.js
//创建一个XMLHttpRequest对象 ,利用此对象域服务器进行通信 是AJAX技术的核心
function ajaxFunction(){
var xmlHttp;
try { // Firefox, Opera 8.0+, Safari
xmlHttp = new XMLHttpRequest();
}
catch (e) {
try {// Internet Explorer
xmlHttp = new ActiveXObject("Msxml2.XMLHTTP");
}
catch (e) {
try {
xmlHttp = new ActiveXObject("Microsoft.XMLHTTP");
}
catch (e) {
}
}
}
return xmlHttp;
}
window.onload = function(){
document.getElementById("ok").onclick = function(){
//1、创建ajax引擎
var xmlHttp = ajaxFunction();
//2、接收服务器端响应的结果
/**
* onreadystatechange:
* * 该事件处理函数由服务器触发,而不是用户
* * 在 Ajax 执行过程中,服务器会通知客户端当前的通信状态。
* 这依靠更新 XMLHttpRequest 对象的 readyState 来实现。改变 readyState 属性是服务器对客户端连接操作的一种方式。
每次 readyState 属性的改变都会触发 readystatechange事件
* readyState:
* readyState 属性表示Ajax请求的当前状态。它的值用数字代表。
0 代表未初始化。 还没有调用 open 方法
1 代表正在加载。 open 方法已被调用,但 send 方法还没有被调用
2 代表已加载完毕。send 已被调用。请求已经开始
3 代表交互中。服务器正在发送响应
4 代表完成。响应发送完毕
* status:
* status 服务器发送的每一个响应也都带有首部信息。
* 三位数的状态码是服务器发送的响应中最重要的首部信息,并且属于超文本传输协议中的一部分。
常用状态码及其含义:
404 没找到页面(not found)
403 禁止访问(forbidden)
500 内部服务器出错(internal service error)
200 一切正常(ok)
304 没有被修改(not modified)(服务器返回304状态,表示源文件没有被修改 )
* 接收服务器的响应结果
* * responseText:XMLHttpRequest 的 responseText 属性包含了从服务器发送的数据。
* 它是一个HTML,XML或普通文本,这取决于服务器发送的内容。
* * responseXML:如果服务器返回的是 XML, 那么数据将储存在 responseXML 属性中。
*
*/
xmlHttp.onreadystatechange = function(){
alert(xmlHttp.readyState);
if(xmlHttp.readyState == 4){
alert(xmlHttp.status);
if(xmlHttp.status == 200 || xmlHttp.status == 304){
var data = xmlHttp.responseText;
alert(data);
}
}
}
//3、打开一个连接
/**
* open(method, url, asynch)
* method:请求类型,类似 “GET”或”POST”的字符串
* url:路径字符串,指向你所请求的服务器上的那个文件。可以是绝对路径或相对路径。
* asynch:表示请求是否要异步传输,默认值为true(异步)
*/
xmlHttp.open("POST","../testServlet?a=8×tamp="+new Date().getTime(),true);
/**
* 如果用 POST 请求向服务器发送数据,
* 需要将 “Content-Type” 的首部设置为 “application/x-www-form-urlencoded”.
* 它会告知服务器正在发送数据,并且数据已经符合URL编码了。
*/
xmlHttp.setRequestHeader("Content-Type","application/x-www-form-urlencoded");
//4、发送请求数据
/**
* send(data):
* * data:将要传递给服务器的字符串
* * 需要传值的时候,可以定义a=8&b=9
*/
xmlHttp.send("b=9&c=10");
}
}
TestServlet.java
package cn.itcast.servlet;
import java.io.IOException;
import java.io.PrintWriter;
import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
@WebServlet("/testServlet")
public class TestServlet extends HttpServlet {
public void doGet(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
request.setCharacterEncoding("UTF-8");
response.setContentType("text/html;charset=utf-8");
PrintWriter out = response.getWriter();
System.out.println("访问服务器成功!调用的方法是doGet");
System.out.println("method:"+request.getMethod());
System.out.println("URL:"+request.getRequestURL());
System.out.println("queryString:"+request.getQueryString());
System.out.println("a:"+request.getParameter("a"));
System.out.println("b:"+request.getParameter("b"));
System.out.println("c:"+request.getParameter("c"));
//将服务器的处理的内容响应到客户端
out.println("发回响应数据,当前请求是:"+request.getMethod());
out.flush();
out.close();
}
public void doPost(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
request.setCharacterEncoding("UTF-8");
response.setContentType("text/html;charset=utf-8");
PrintWriter out = response.getWriter();
System.out.println("访问服务器成功!调用的方法是doPost");
System.out.println("method:"+request.getMethod());
System.out.println("URL:"+request.getRequestURL());
System.out.println("queryString:"+request.getQueryString());
System.out.println("a:"+request.getParameter("a"));
System.out.println("b:"+request.getParameter("b"));
System.out.println("c:"+request.getParameter("c"));
//将服务器的处理的内容响应到客户端
out.println("发回响应数据,当前请求是:"+request.getMethod());
out.flush();
out.close();
}
}
运行效果: