当前位置: 首页 > 编程笔记 >

实例解读Ajax与servlet交互的方法

柯学
2023-03-14
本文向大家介绍实例解读Ajax与servlet交互的方法,包括了实例解读Ajax与servlet交互的方法的使用技巧和注意事项,需要的朋友参考一下

本文以实例形式剖析了Ajax与servlet的交互,并且代码中有较为详细的注释,以帮助大家阅读理解。具体的实现方法如下:

1.JavaScript部分

var req;
 /*通过异步传输XMLHTTP发送参数到ajaxServlet,返回符合条件的XML文档*/
 var url;
 function getResult()
 { 
  var f=document.getElementById("form_pub");
  var key=f.s.options[f.s.selectedIndex].text; //获取对select中文本的引用
 if (window.XMLHttpRequest)
 {
  req = new XMLHttpRequest();
  url = "ajaxServlet?action="+key+"&bm=UTF-8";
 }else if (window.ActiveXObject)
 {
 
  req = new ActiveXObject("Microsoft.XMLHTTP");
  url = "ajaxServlet?action="+key+"&bm=gbk";
 }
 if(req)
 { 
  req.open("GET",url, true); 
  req.setRequestHeader("Content-Type", "text/html;charset=UTF-8");
  //这里如果不设定头部则会导致 firfox 发送数据错误,servlet接受到的参数为乱码,在IE中正常
  req.onreadystatechange = complete; 
  req.send(null);
  //req.setRequestHeader("Content-Type", "text/xml; charset=UTF-8"); 
 }
 }
 /*分析返回的XML文档*/
 function complete(){
 if (req.readyState == 4)
 {
  if (req.status == 200)
  {
   var items=document.getElementById("belong");
  //以下为解析返回的XML文档  
   var xmlDoc = req.responseXML;
   var Node=xmlDoc.getElementsByTagName("type_name");
   //var str=new Array();
    var str=null;
    //清空工作
    items.innerHTML=""; //删除一个 select内的全部内容
 for(var i=0;i<Node.length;i++)
    { 
     str=Node[i];
     //alert(str.childNodes[0].nodeValue);
     var objectOption=document.createElement("option");
      items.options.add(objectOption);
     //firfox不支持innerText必须用textContent代替
      if (window.ActiveXObject)
      {objectOption.innerText=str.childNodes[0].nodeValue;}
      else
      {objectOption.textContent=str.childNodes[0].nodeValue;}
    }
   }
  }
 }

2.servlet端:

package ajax;

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 Data_GetConn.GetConn;//这个包是自己写的为获取对mysql的引用
import java.sql.*;//这个包必须有!!


public class ajaxServlet extends HttpServlet{
 //private static final String CONTENT_TYPE = "text/xml; charset=UTF-8";//这里最好统一用UTF-8进行编码
 public void init() throws ServletException{}
 public void doGet(HttpServletRequest request,HttpServletResponse response) throws ServletException, IOException
 {
 response.setContentType("text/xml; charset=UTF-8");
 //以下两句为取消在本地的缓存
 response.setHeader("Cache-Control", "no-cache");
  response.setHeader("Pragma", "no-cache");
 PrintWriter out = response.getWriter();
 String action = request.getParameter("action");
 String bm = request.getParameter("bm");
 
 if(("gbk").equals(bm))
 {
  action=new String(action.getBytes("ISO-8859-1"),"gbk");//将获得的数据用gbk从新编码!(感谢董卫老师)
 }
 else
 {
   action=new String(action.getBytes("ISO-8859-1"),"gbk");
 }
 try
  {
   GetConn wq=new GetConn();
   Connection   con=wq.getCon();
   Statement stmt=con.createStatement();
   ResultSet rs=stmt.executeQuery("select items from class where main='"+action+"'");
   StringBuffer sb = new StringBuffer();
    sb.append("<type>");
   while(rs.next())
   {
      
   sb.append("<type_name>"+rs.getString(1)+"</type_name>");
     
   }
    //sb.append("<type_name>"+action+"</type_name>");
    sb.append("</type>"); 
    out.write(sb.toString());//注意这里向jsp输出的流,在script中的截获方法
    out.close();
    stmt.close();
    con.close();
  }
  catch(Exception ex)
  {
     
  }
 
 }
}
 类似资料:
  • 本文向大家介绍Servlet 与 Ajax 交互一直报status=parsererror的解决办法,包括了Servlet 与 Ajax 交互一直报status=parsererror的解决办法的使用技巧和注意事项,需要的朋友参考一下 原因:servlet 返回的数据不是 Json 格式 1、JS代码为: 2、注意上面的 url 为 /LSHome/LSHome,(项目名称为LSHome)所以在

  • 这个剧本 }); 正在引起通信路由的错误 /updatechat 但是如果在前一段代码中,我替换为 这个"var=request.form['var']"表单在我的代码中的几个不同的路由上工作

  • 本文向大家介绍C++与Lua交互原理实例详解,包括了C++与Lua交互原理实例详解的使用技巧和注意事项,需要的朋友参考一下 首先,不同语言交互,我们一般把这种编程方式称为混合编程。开发中为什么要多语言混合使用,只用c++不行吗?答案是因为脚本语言语法糖多使用方便、沙盒式安全机制使系统更稳定、简单易学降低开发成本等,那么,只用脚本不行吗?那也是不合理的,因为与系统api的接口、计算密集性模块的性能要

  • 本文向大家介绍php和nginx交互实例讲解,包括了php和nginx交互实例讲解的使用技巧和注意事项,需要的朋友参考一下 Nginx与PHP交互过程的7步走(用户对动态PHP网页访问过程) step1:用户将http请求发送给nginx服务器(用户和nginx服务器进行三次握手进行TCP连接)。 step2:nginx会根据用户访问的URL和后缀对请求进行判断。 step3:通过第二步可以看出,

  • 前面的章节,我们主要从什么是 Ajax、为什么要用 Ajax、Ajax 是如何实现的以及如何封装一个 Ajax来对 Ajax 做一个多方位的学习。从前面章节的学习中,相信同学们对 Ajax 都会有一个比较完整的概念了。那么,接下来的这个章节,我们着重列举一个示例,来讲述 Ajax 是如何进行前后端交互的。 本章须知 本章节会给出前后端简单代码,弱化容错性等增强性需求,重点描述前后端交互的过程和效果

  • 本文向大家介绍Android中WebView与Js交互的实现方法,包括了Android中WebView与Js交互的实现方法的使用技巧和注意事项,需要的朋友参考一下 获取WebView对象 调用WebView对象的getSettings()方法,获取WebSettings对象 调用WebSettings对象的setJavaScriptEnabled()方法,设置js可用,参数:布尔值 在判断是否支持