`

基于Servlet AJAX

阅读更多
优点:异步交互,用户感觉不到页面的提交,当然也不等待页面返回。
响应速度快。
复杂的UI成功处理,一直以来,我们对B/S模式的UI不如C/S模式UI丰富而苦恼,现在由于AJAX大量使用JS,使得复杂的UI设计变得更加成功。
最后AJAX请求的返回对象为XML文件,易于和WEB SERVICE结合起来。


基于Servlet为后台的一个web应用例子:
关于关联选择框的问题:
当用户在第一个选择框里选择ZHEJIANGS时,第二个选择框要出现ZHEJIANG的城市;当用户在第一个选择框里选择JIANGSU时,第二个选择框里要出现JIANGSU的城市
首先,配置文件web.xml,在里面配置servlet,跟往常一样:
<web-app version="2.4"   
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"> 

<servlet>
<servlet-name>SelectCityServlet</servlet-name>
<servlet-class>com.stephen.servlet.SelectCityServlet</servlet-class>
</servlet>

<servlet-mapping>
<servlet-name>SelectCityServlet</servlet-name>
<url-pattern>/servlet/SelectCityServlet</url-pattern>
</servlet-mapping>

</web-app>


JSP文件:
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
<head>
<title>MyHtml.html</title>

<meta http-equiv="keywords" content="keyword1,keyword2,keyword3">
<meta http-equiv="description" content="this is my page">

<!--link rel="stylesheet" type="text/css" href="./style.css">HTML显式注释-->

</head>
<script type="text/javascript">
function getResult(stateVal){
  var url = "servlet/ServletCityServlet?state="+stateVal;
  if(window.XMLHttpRequest){//code for all new browsers
    req = new XMLHttpRequest();
  }else if(window.ActiveXObject){//code for IE5 IE6
    req = new ActiveXObject("Microsoft.XMLHTTP");
  }
  if(req){
    req.open("GET",url,true);
    req.onreadystatechange = complete;
    req.send(null);
  }  
}
function complete(){
  if(req.readyState == 4){//4 = "loaded"
    if(req.status == 200){//200 = OK
      var city = req.responseXML.getElementsByTagName("city");
      //alert(city.length)
      var str = new Array();
      for(var i=0;i<city.length;i++){
        str[i]=city[i].firstChild.data;
      }
      //alert(document.getElementById("city"));
      buildSelect(str,document.getElementById("city"));
    }
  }
}
function buildSelect(str,sel){
  sel.options.length=0;
  for(var i=0;i<str.length;i++){
    sel.options[sel.options.length] = new Option(str[i],str[i])
  }
}
</script>
<body>
<select name="state" onChange="getResult(this.value)">
  <option value="">Select</option>
  <option value="zj">ZEHJIANG</option> 
  <option value="js">JIANGSU</option>
</select>
<select id="city">
  <option value="">CITY</option>
</select>
</body>
</html>

JS的不同
getResult(stateVal)方法,取得XmlHttpRequest;然后设置该请求的url:req.open("GET",url,true);接着设置请求返回值的接收方法:req.onreadystatechange = complete;该返回值的接收方法为  complete();最后是发送请求:req.send(null);

然后是返回值接收方法:complete(),这个方法,首先判断是否正确返回,如正确返回,用DOM对返回的XML文件进行解析。得到city值后,再通过buildSelect(str,sel)方法赋值到相应的选择框里面。

onreadystatechange是一个事件句柄,他的值complete是一个函数名称,当XMLHttpRequest对象的状态发生改变时,会触发此函数。状态从0到4进行变化。仅在状态为4时,才执行代码。
为什么使用Async=true?
open()的第三个参数中使用了"true"
该参数规定请求是否异步处理。
True表示脚本会在send()方法之后继续运行,而不等待来自服务器的响应。
onreadystatechange事件使代码复杂化了。但是这是在没有得到服务器响应的情况下,防止代码停止的最安全的方法。
通过把该参数设置为"false",可以省去额外的onreadystatechange代码。如果在请求失败时是否执行其余的代码无关紧要,那么就可以使用这个参数。

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 SelectCityServlet extends HttpServlrt{
  public SelectCityServlet(){
    super();
  }
  public void destory(){
    super.destory();
  }

  public void doGet(HttpServletRequest request,HttpServletResponse  
                    response)throws ServletException IOException{
    response.setContentType("text/xml");
    response.setHeader("Cache-Control","no-cache");
    String state = request.getParamter("state");
    StringBuffer sb = new StringBuffer("<state>");
    if("zj".equals(state)){
      sb.append("<city>hangzhou</city><city>huzhou</city>");
    }else if("js".equals(state)){
      sb.append("<city>nanjing</city><city>wuxi</city>");
    }
    sb.append("</state>");
    PrintWriter out = response.getWriter();
    out.write(sb.toString());
    //out.write只能输出字符串,out.print可以输出Java对象
    out.close;
  }
}

这个类,首先是从request里取得state参数,然后根据state参数生成相应的XML文件,最后将XML文件输出到PrintWriter对象里。
分享到:
评论

相关推荐

    基于jsp+servlet+ajax的图书管理系统.zip

    基于jsp+servlet+ajax的图书管理系统基于jsp+servlet+ajax的图书管理系统 基于jsp+servlet+ajax的图书管理系统基于jsp+servlet+ajax的图书管理系统 基于jsp+servlet+ajax的图书管理系统基于jsp+servlet+ajax的图书...

    基于jsp+servlet+Ajax异步登陆模拟web项目

    【基于jsp+servlet+Ajax异步登陆模拟web项目】是一个典型的Web开发实例,它整合了三种核心技术:JavaServer Pages(JSP)、Servlet以及Asynchronous JavaScript and XML(Ajax)。这个项目的核心目的是实现用户登录...

    基于Servlet+JSP+Jquery+EL+Ajax的餐饮管理系统源码.zip

    基于Servlet+JSP+Jquery+EL+Ajax的餐饮管理系统源码.zip基于Servlet+JSP+Jquery+EL+Ajax的餐饮管理系统源码.zip基于Servlet+JSP+Jquery+EL+Ajax的餐饮管理系统源码.zip基于Servlet+JSP+Jquery+EL+Ajax的餐饮管理系统...

    基于servlet+ajax用户注册登录系统.zip

    作业:用户登录注册系统,后台采用jsp + servlet + javabean技术实现,浏览器客户端采用ajax框架之jquery框架! 要求: 不能抄袭,没有分组,面向接口编程,不要迟到! 1、注册的信息: 用户名,密码,性别(下拉...

    基于Ajax和servlet的网页聊天工具

    总结来说,这个基于Ajax和Servlet的网页聊天工具利用了现代Web技术,实现了高效的、无需刷新页面的实时聊天功能。通过MySQL数据库保证了数据的安全存储,Tomcat作为服务器环境提供了稳定的支持。前端的JavaScript和...

    精选_基于Servlet和Ajax实现搜索框智能提示_源码打包

    "精选_基于Servlet和Ajax实现搜索框智能提示_源码打包" 这个标题揭示了我们讨论的核心技术主题。首先,“Servlet”是Java Web开发中的一个重要组件,用于处理HTTP请求并返回响应。它在服务器端运行,为Web应用提供...

    Ajax+Servlet 实例

    **Ajax+Servlet 实例** Ajax(Asynchronous JavaScript and XML)技术是现代Web开发中的关键组成部分,它允许在不刷新整个页面的情况下与服务器进行异步数据交互。Servlet是Java Web开发中的一个标准,用于处理和...

    基于servlet+ajax用户注册登录系统小例子

    作业:用户登录注册系统,后台采用jsp + servlet + javabean技术实现,浏览器客户端采用ajax框架之jquery框架! 要求: 不能抄袭,没有分组,面向接口编程,不要迟到! 1、注册的信息: 用户名,密码,性别(下拉...

    基于servlet网页聊天室

    【标题】:基于Servlet网页聊天室 【描述】:这个项目是使用Java、Servlet和JSP技术构建的一个在线聊天平台,特别关注客户与客服之间的实时通信。聊天记录被存储在Servlet上下文(servletContext)中,以实现数据的...

    基于servlet和ajax的图书管理系统.zip

    【标题】基于servlet和ajax的图书管理系统是一个典型的Java Web应用程序,它利用了Servlet技术来处理服务器端的请求,以及Ajax(异步JavaScript和XML)技术来实现页面的无刷新更新,提供用户友好的交互体验。...

    简单的Ajax聊天室样例(servlet+jsp)

    【Ajax聊天室】是一个基于Java Web技术实现的简单交互式应用,主要利用了Servlet、JSP和Ajax技术。这个小例子展示了如何通过Ajax实现在不刷新整个页面的情况下更新内容,提供了一个基本的在线聊天功能。 1. **...

    jsp+servlet+Ajax 购物车

    【标题】:“jsp+servlet+Ajax 购物车”技术实现详解 在现代Web开发中,构建一个功能完善的购物车系统是常见的需求。这里我们将深入探讨如何利用Java的JSP(JavaServer Pages)、Servlet以及Ajax(Asynchronous ...

    基于Servlet的图书管理系统.zip

    《基于Servlet的图书管理系统》是一个JavaWeb应用,它利用了前后端分离的设计模式,将业务逻辑处理和用户界面展示分开,以提高系统的可维护性和用户体验。在这个系统中,Servlet作为后端服务,处理HTTP请求,执行...

    ajax+json+servlet下载

    以下是对这个"ajax+json+servlet下载"主题的详细解释。 首先,我们需要理解Ajax的核心原理。Ajax通过XMLHttpRequest对象在后台与服务器进行通信,而不会打断用户的交互。这使得网页能够异步地更新,提升了用户体验...

    基于jsp+servlet+ajax的web聊天室

    使用servlet+ajax实现无刷新发言与更新实时聊天记录以及注册时文本框失去焦点AJAX验证用户名是否已重复; 系统支持双人聊天与群聊,群聊登陆界面为webLogin.jsp 双人聊天为login.jsp。在注册以后均可以登陆系统进行...

    java+servlet+ajax程序

    【Java + Servlet + Ajax 程序详解】 Java、Servlet 和 Ajax 是构建动态网站的关键技术,它们共同为用户提供了交互性和实时更新的能力。本指南将深入解析这些技术,并结合实际应用,帮助您理解和掌握如何利用它们来...

    AjaxServlet

    AjaxServlet是一个基于Ajax、Servlet和JSP技术的搜索框开发示例。这个项目展示了如何使用这些技术来实现页面异步更新,提供用户友好的搜索体验。在传统的Web应用中,每当用户提交表单,整个页面都需要刷新以显示新...

    基于servlet的学生管理系统

    【基于Servlet的学生管理系统】是一种基于Java Web技术的后端应用程序,用于高效地管理和查询学生信息。Servlet是Java编程语言中的一个接口,它扩展了Web服务器的功能,允许开发人员创建动态、交互式的Web应用。在本...

    基于Servlet+JSP+Ajax的在线聊天室Demo

    总的来说,这个基于Servlet+JSP+Ajax的在线聊天室Demo提供了一个完整的示例,展示了如何利用Java Web技术实现一个实时交互的聊天应用。通过学习和实践,开发者可以加深对Web开发的理解,掌握服务器端和客户端的交互...

    基于servlet的文件上传

    本示例基于Servlet和Apache Commons FileUpload库实现了一个简单的文件上传系统。下面将详细介绍这个过程及其涉及到的关键知识点。 首先,`servlet`是Java EE(企业版)的一部分,它是一种用于扩展Web服务器功能的...

Global site tag (gtag.js) - Google Analytics