AJAX中GET请求
testget.jsp
<%@ page language="java" pageEncoding="utf-8"%>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
<head>
<script type="text/javascript" src="./test.js"></script>
</head>
<body>
<form action="" enctype="application/x-www-form-urlencoded">
<input type="button" name="ok" id="ok" value="测试服务器连接">
</form>
</body>
</html>
get.js
//当页面内容加载完毕之后,再执行以下代码
window.onload = function(){
document.getElementById("ok").onclick = function(){
//实现Ajax异步交互,与页面的表单没有关系(不可能有关系)
//1 创建XMLHttpRequest对象:属性和方法
var xhr = ajaxFunction();
/*
* 2 客户端与服务器端建立连接
*
* 利用XMLHttpRequest对象的open(method, url, asynch)方法
* * method:请求类型,GET或POST.
* * url:请求路径,可以是相对路径或绝对路径.
* * asynch:表示是否异步,true(默认值)表示异步
*/
xhr.open("get","../testServlet?timeStamp="+new Date().getTime()+"&c=9",true);
/*
* 3 客户端向服务器端发送请求
*
* 利用XMLHttpRequest对象的send()方法
* * 如果请求类型是GET方式的话,send()方法发送请求数据,服务器端接收不到
* * 该步骤不能被省略,以下内容可以改写为:xhr.send(null);
*/
xhr.send("a=7&b=8");
/*
* 4 服务器端向客户端进行响应
*
* 利用XMLHttpRequest对象的onreadystatechange属性:用于监听服务器端的状态
*
* readyState 属性表示Ajax请求的当前状态。它的值用数字代表。
0 代表未初始化。 还没有调用 open 方法
1 代表正在加载。 open 方法已被调用,但 send 方法还没有被调用
2 代表已加载完毕。send 已被调用。请求已经开始
3 代表交互中。服务器正在发送响应
4 代表完成。响应发送完毕
*
* 常用状态码及其含义:
404 没找到页面(not found)
403 禁止访问(forbidden)
500 内部服务器出错(internal service error)
200 一切正常(ok)
304 没有被修改(not modified)(服务器返回304状态,表示源文件没有被修改 )
*/
xhr.onreadystatechange = function(){
//接收服务器端的通信状态
//alert(xhr.readyState); //2,3,4一共三个状态,只关注4的状态
//alert(xhr.status);
if(xhr.readyState==4){
if(xhr.status==200||xhr.status==304){
//接收服务器端的响应结果
var data = xhr.responseText;
alert(data);
}
}
}
}
//是固定写法
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;
}
}
AJAX中POST请求
testpost.jsp
<%@ page language="java" pageEncoding="utf-8"%>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
<head>
<script type="text/javascript" src="./test.js"></script>
</head>
<body>
<form method="post" action="" enctype="application/x-www-form-urlencoded">
<input type="button" name="ok" id="ok" value="测试服务器连接">
</form>
</body>
</html>
post.js
window.onload = function(){
document.getElementById("ok").onclick = function(){
//1、创建XMLHttpRequest对象
var xhr = ajaxFunction();
/*
* 2 注册监听
* readyState 属性表示Ajax请求的当前状态。它的值用数字代表。
0 代表未初始化。 还没有调用 open 方法
1 代表正在加载。 open 方法已被调用,但 send 方法还没有被调用
2 代表已加载完毕。send 已被调用。请求已经开始
3 代表交互中。服务器正在发送响应
4 代表完成。响应发送完毕
注意:理论上永远得不到.
*/
xhr.onreadystatechange = function(){
alert(xhr.readyState);
if(xhr.readyState==4){
if(xhr.status==200||xhr.status==304){
var data = xhr.responseText;
alert(data);
}
}
}
//3、客户端与服务器端建立连接
xhr.open("post","../testServlet?timeStamp="+new Date().getTime(),true);
//如果请求类型是POST方式的话,需要设置请求首部信息
xhr.setRequestHeader("Content-Type","application/x-www-form-urlencoded");
/*
* 4
* send()方法与请求类型没有关系?存在关系
* * 如果请求类型是GET方式的话,send()方法发送的请求数据,服务器端接收不到
* * 该步骤不能被省略,改写为:xhr.send(null);
* * 如果请求类型是POST方式的,send()方法发送的请求数据,服务器端可以接收
* * 必须要设置请求首部信息:"Content-Type"为"application/x-www-form-urlencoded"
*/
xhr.send("a=7&b=8");
}
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;
}
}
**************************************************************************************************************************************************************************************
TestServlet.java
package app.servlet;
import java.io.IOException;
import java.io.PrintWriter;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
public class TestServlet extends HttpServlet {
public void doGet(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
response.setContentType("text/html");
PrintWriter out = response.getWriter();
//如果打印这句话,说明建立连接成功
System.out.println("connection server success!");
//如果打印这句话,说明发送请求数据成功
System.out.println("a = "+request.getParameter("a"));
System.out.println("b = "+request.getParameter("b"));
System.out.println("c = "+request.getParameter("c"));
//向客户端进行响应
out.println("get connection server success!");
}
public void doPost(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
response.setContentType("text/html");
PrintWriter out = response.getWriter();
//如果打印这句话,说明建立连接成功
System.out.println("connection server success!");
//如果打印这句话,说明发送请求数据成功
System.out.println("a = "+request.getParameter("a"));
System.out.println("b = "+request.getParameter("b"));
//向客户端进行响应
out.println("post connection server success!");
}
}