Ajax 与 Servlet
来源:互联网 发布:mac 添加用户组命令 编辑:程序博客网 时间:2024/06/07 20:57
Ajax异步请求,servlet产生随机数据,Html页面无刷新显示。
运行环境:jdk1.5+tomcat 5.5
一、ajaxServlet.java
package com;
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;
import java.util.Random;
public class ajaxServlet extends HttpServlet...{
private static final String CONTENT_TYPE="text/xml; charset=gb2312";
public void init() throws ServletException...{}
public void doGet(HttpServletRequest request,HttpServletResponse response)
throws ServletException,IOException...{
response.setContentType(CONTENT_TYPE);
response.setHeader("Cache-Control","no-cache");
response.setHeader("Pragma","no-cache");
response.setDateHeader("Expires",0);
PrintWriter out=response.getWriter();
String action=request.getParameter("action");
if(("send").equals(action))...{
Random random = new Random();
String AA=Integer.toString(Math.abs(random.nextInt()));
String BB=Integer.toString(Math.abs(random.nextInt()));
String CC=Integer.toString(Math.abs(random.nextInt()));
String DD=Integer.toString(Math.abs(random.nextInt()));
StringBuffer sb=new StringBuffer();
sb.append(AA); sb.append("@@@");
sb.append(BB); sb.append("@@@");
sb.append(CC); sb.append("@@@");
sb.append(DD);
out.write(sb.toString());
out.close();
} }}
二、testajax.html
<html>
<head>
<title>AJAX.html</title>
</head>
<script type="text/javascript">
function getResult()...{
var url = "/Tajax/AajaxServlet?action=send";
if (window.XMLHttpRequest) ...{
req = new XMLHttpRequest();
}else if (window.ActiveXObject)...{
req = new ActiveXObject("Microsoft.XMLHTTP");
}
if(req)...{
req.open("GET",url, true);
req.onreadystatechange = complete;
req.send(null);
}
}
/**//*分析返回的文本文档*/
function complete()...{
if (req.readyState == 4) ...{
if (req.status == 200) ...{
// alert(req.responseText);
var strResult = unescape(req.responseText);
var arrResult = strResult.split("@@@");
RemoveRow(); //删除以前的数据.
num1 = arrResult[0]; //字段num1的值
num2 = arrResult[1]; //字段num2的值
num3 = arrResult[2];
num4 = arrResult[3];
row1= tb.insertRow();
cell1 = row1.insertCell();
cell1.innerText = num1;
cell2 = row1.insertCell();
cell2.innerText = num2;
row2= tb.insertRow();
cell3 = row2.insertCell();
cell3.innerText = num3;
cell4 = row2.insertCell();
cell4.innerText = num4;
} else ...{
alert('There was a problem with the request.');
}
}
}
function RemoveRow()...{//保留第一行表头,其余数据均删除.
var iRows = tb.rows.length;
for(var i=0;i< iRows-1;i++)...{
tb.deleteRow(1);
}
}
function MyShow()...{//2秒自动刷新一次,2秒取得一次数据.
timer = window.setInterval("getResult()",2000);
}
</script>
<body onload="MyShow()">
<table width="47%" height="23" border="0" cellpadding="1" cellspacing="0" id="tb">
<tr><td>代码</td>
<td>价格</td>
</tr>
</table>
<form>
<p>输入股票代码:
<input type="text" size="14" name="phone" id="phone"/>
</p>
<p>你交易的数量:</p>
<p><textarea name="order" rows="6" cols="50" id="order"></textarea></p>
<p><input type="submit" value="提交" id="submit" /></p>
</form>
</body>
三、web.xml
<?xml version="1.0" encoding="ISO-8859-1"?>
<web-app xmlns="http://java.sun.com/xml/ns/j2ee"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://java.sun.com/xml/ns/j2ee http://java.sun.com/xml/ns/j2ee/web-app_2_4.xsd"
version="2.4">
<display-name>Welcome to Tomcat</display-name>
<description>
Welcome to Tomcat
</description>
<servlet>
<servlet-name>AajaxServlet</servlet-name>
<servlet-class>com.ajaxServlet</servlet-class>
</servlet>
<servlet-mapping>
<servlet-name>AajaxServlet</servlet-name>
<url-pattern>/AajaxServlet</url-pattern>
</servlet-mapping>
</web-app>
运行环境:jdk1.5+tomcat 5.5
一、ajaxServlet.java
package com;
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;
import java.util.Random;
public class ajaxServlet extends HttpServlet...{
private static final String CONTENT_TYPE="text/xml; charset=gb2312";
public void init() throws ServletException...{}
public void doGet(HttpServletRequest request,HttpServletResponse response)
throws ServletException,IOException...{
response.setContentType(CONTENT_TYPE);
response.setHeader("Cache-Control","no-cache");
response.setHeader("Pragma","no-cache");
response.setDateHeader("Expires",0);
PrintWriter out=response.getWriter();
String action=request.getParameter("action");
if(("send").equals(action))...{
Random random = new Random();
String AA=Integer.toString(Math.abs(random.nextInt()));
String BB=Integer.toString(Math.abs(random.nextInt()));
String CC=Integer.toString(Math.abs(random.nextInt()));
String DD=Integer.toString(Math.abs(random.nextInt()));
StringBuffer sb=new StringBuffer();
sb.append(AA); sb.append("@@@");
sb.append(BB); sb.append("@@@");
sb.append(CC); sb.append("@@@");
sb.append(DD);
out.write(sb.toString());
out.close();
} }}
二、testajax.html
<html>
<head>
<title>AJAX.html</title>
</head>
<script type="text/javascript">
function getResult()...{
var url = "/Tajax/AajaxServlet?action=send";
if (window.XMLHttpRequest) ...{
req = new XMLHttpRequest();
}else if (window.ActiveXObject)...{
req = new ActiveXObject("Microsoft.XMLHTTP");
}
if(req)...{
req.open("GET",url, true);
req.onreadystatechange = complete;
req.send(null);
}
}
/**//*分析返回的文本文档*/
function complete()...{
if (req.readyState == 4) ...{
if (req.status == 200) ...{
// alert(req.responseText);
var strResult = unescape(req.responseText);
var arrResult = strResult.split("@@@");
RemoveRow(); //删除以前的数据.
num1 = arrResult[0]; //字段num1的值
num2 = arrResult[1]; //字段num2的值
num3 = arrResult[2];
num4 = arrResult[3];
row1= tb.insertRow();
cell1 = row1.insertCell();
cell1.innerText = num1;
cell2 = row1.insertCell();
cell2.innerText = num2;
row2= tb.insertRow();
cell3 = row2.insertCell();
cell3.innerText = num3;
cell4 = row2.insertCell();
cell4.innerText = num4;
} else ...{
alert('There was a problem with the request.');
}
}
}
function RemoveRow()...{//保留第一行表头,其余数据均删除.
var iRows = tb.rows.length;
for(var i=0;i< iRows-1;i++)...{
tb.deleteRow(1);
}
}
function MyShow()...{//2秒自动刷新一次,2秒取得一次数据.
timer = window.setInterval("getResult()",2000);
}
</script>
<body onload="MyShow()">
<table width="47%" height="23" border="0" cellpadding="1" cellspacing="0" id="tb">
<tr><td>代码</td>
<td>价格</td>
</tr>
</table>
<form>
<p>输入股票代码:
<input type="text" size="14" name="phone" id="phone"/>
</p>
<p>你交易的数量:</p>
<p><textarea name="order" rows="6" cols="50" id="order"></textarea></p>
<p><input type="submit" value="提交" id="submit" /></p>
</form>
</body>
三、web.xml
<?xml version="1.0" encoding="ISO-8859-1"?>
<web-app xmlns="http://java.sun.com/xml/ns/j2ee"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://java.sun.com/xml/ns/j2ee http://java.sun.com/xml/ns/j2ee/web-app_2_4.xsd"
version="2.4">
<display-name>Welcome to Tomcat</display-name>
<description>
Welcome to Tomcat
</description>
<servlet>
<servlet-name>AajaxServlet</servlet-name>
<servlet-class>com.ajaxServlet</servlet-class>
</servlet>
<servlet-mapping>
<servlet-name>AajaxServlet</servlet-name>
<url-pattern>/AajaxServlet</url-pattern>
</servlet-mapping>
</web-app>
- ajax 与 servlet
- Ajax 与 Servlet
- servlet与ajax的结合
- ajax学习之-----ajax与servlet
- ajax与servlet的一个简单分页
- ajax与servlet利用json传送数据
- Ajax与servlet交互的实例
- jquery的ajax请求servlet与响应
- Ajax与servlet交互的实例【转】
- AJAX与Servlet的相关使用
- ajax说明与servlet 的作用
- Ajax与Servlet的数据交互
- Ajax与servlet交互的实例
- ajax与servlet的动态交互
- ajax与servlet交互实例,初学者看
- ajax与servlet之间的交互方式
- jquery的ajax请求servlet与响应
- ajax与servlet--验证用户名是否存在
- Donet 夏令时的处理(记忆)
- Oracle数据库导入数据的方法
- IT售前经理成功签单6式
- RBAC角色权限模型设计
- 对Datset导出XML到客户端的一些补充
- Ajax 与 Servlet
- j2me 资料网站
- 一定要搞定fp-growth数据挖掘模块。
- 抨击匈牙利命名法
- 关于XmlTextWriter的使用方法
- ADO.NET 的最佳实践技巧
- asp.net调用远程Web Service的二种方法
- ECHO命令的使用
- 实现千万级数据的分页显示