实例解读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)
  {

  }

 }
}
(0)

相关推荐

  • Javascript发送AJAX请求实例代码

    一个对AJAX的封装 //url就是请求的地址 //successFunc就是一个请求返回成功之后的一个function,有一个参数,参数就是服务器返回的报文体 function ajax(url,successFunc) { var xhr = window.XMLHttpRequest ? new XMLHttpRequest() : new ActiveXObject('Microsoft.XMLHTTP'); xhr.open("POST",url,true); xhr.onr

  • javascript请求servlet实现ajax示例(分享)

    ajax请求是一种无刷新式的用户体验,可以发送GET和POST两种异步请求,现记录如下: GET请求: function sendRequestByGet(){ //定义异步请求对象 var xmlReq; //检测浏览器是否直接支持ajax if(window.XMLHttpRequest){//直接支持ajax xmlReq=new XMLHttpRequest(); }else{//不直接支持ajax xmlReq=new ActiveObject('Microsoft.XMLHTTP')

  • 原生js实现ajax方法(超简单)

    上一篇文章写到原生js取代jquery的一些常用函数:原生js仿jquery一些常用方法,那么,ajax如何实现呢?如下是一个比较完整的ajax() function ajax(){ var ajaxData = { type:arguments[0].type || "GET", url:arguments[0].url || "", async:arguments[0].async || "true", data:arguments[0].d

  • 原生JS简单实现ajax的方法示例

    本文实例讲述了原生JS简单实现ajax的方法.分享给大家供大家参考,具体如下: HTML部分: <body> <input type="button" value="Ajax提交" onclick="Ajax();" /> <div id="resText" ></div> </body> 这里有个input按钮,点击会触发click事件,click事件调用Ajax(

  • 实例解读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]

  • Django中使用jquery的ajax进行数据交互的实例代码

    jquery框架中提供了$.ajax.$.get.$.post方法,用于进行异步交互,由于Django中默认使用CSRF约束,推荐使用$.get 示例:实现省市区的选择 最终实现效果如图: 将jquery文件拷贝到static/js/目录下 打开booktest/views.py文件,定义视图area1,用于显示下拉列表 #提供显示下拉列表的控件,供用户操作 def area1(request): return render(request,'booktest/area1.html') 打开bo

  • 原生JS实现Ajax通过POST方式与PHP进行交互的方法示例

    本文实例讲述了原生JS实现Ajax通过POST方式与PHP进行交互的方法.分享给大家供大家参考,具体如下: 一.代码 conn.php <?php $conn=mysql_connect("localhost","root","root") or die("数据库连接失败".mysql_error()); mysql_select_db("db_database27",$conn) or die(&q

  • TP5(thinkPHP5)框架使用ajax实现与后台数据交互的方法小结

    本文实例讲述了TP5(thinkPHP5)框架使用ajax实现与后台数据交互的方法.分享给大家供大家参考,具体如下: 方法一: serialize() 方法通过序列化表单值,创建 URL 编码文本字符串,这个是jquery提供的方法 前端代码 <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title>ajax交互</title> <script s

  • 基于js原生和ajax的get和post方法以及jsonp的原生写法实例

    login.onclick = function(){ var xhr = new XMLHttpRequest(); xhr.open("get","http://localhost/ajax2/test2.php?username="+username.value+"&pwd="+pwd2.value,true); xhr.send(); xhr.onreadystatechange = function(){ if (xhr.rea

  • jQuery中ajax的load()与post()方法实例详解

    本文实例讲述了jQuery中ajax的load()与post()方法.分享给大家供大家参考,具体如下: 一.load()方法 在jQuery ajax的load()方法能够载入远程 HTML 文件代码并插入至 DOM 中,这个与post,get还是有一点的区别,但可以快速在页面加载时就加载一个页面的html保存到dom中并且可执行哦. load()方法默认使用 GET 方式, 如果传递了data参数则使用Post方式. 传递附加参数时自动转换为 POST 方式.jQuery 1.2 中,可以指定

  • Ajax对缓存的处理方法实例分析

    本文实例讲述了Ajax对缓存的处理方法.分享给大家供大家参考,具体如下: 缓存 浏览器的一次请求需要从服务器获得许多的css.img.js等相关文件,如果每次请求都把相关的资源文件加载一次,对带宽.服务器资源.用户等待时间都有严重的损耗,浏览器有做优化处理,其把css.img.js等文件在第一次请求成功后就在本地保留一个缓存备份,后续的每次请求就在本身获得相关的缓存资源文件,可以明显的加快用户的访问速度. css.img.js等静态文件可以缓存,但是动态程序文件如php文件就不能缓存,即使缓存我

  • 在SSM框架下用laypage和ajax实现分页和数据交互的方法

    layui,一款前端框架,提供了丰富的组件和模板,layui提供的简约后台管理模板,对于后端学习者来说是个不错的福音.这里记录在SSM框架下使用layui的分页组件laypage.(官网开发文档) 环境 Spring+SpringMVC+Mybatis , jquery-3.1.0.min.js , mysql-connector-java-5.1.34 参考文档 layui-laypage参数文档 前端代码主要参考的是layui官网给定的代码,加载layui.css和layui.js:除此之外

  • 微信小程序与后台PHP交互的方法实例分析

    本文实例讲述了微信小程序与后台PHP交互的方法.分享给大家供大家参考,具体如下: 接下来将讲后台如何与前台进行数据及图片之间的交互,相信这一点是很多人所关注的,因为当时我实在团队中负责后台开发,因此对前端不是特别了解,这里我会贴出前端开发时的部分代码截图,微信小程序的官方api介绍地址是: https://mp.weixin.qq.com/debug/wxadoc/dev/api/api-network.html 微信与后台服务器之间的数据通信是调用wx.request(OBJECT)实现的,官

  • JS的Ajax与后端交互数据的实例

    JS中很多地方会使用Ajax与后台进行数据交互. Ajax是通过http,使得JS与后端进行数据通信,由于Ajax的异步特性,可以使多个Ajax请求同时访问后端,对页面的局部数据进行逻辑处理,并渲染. ajax中前端和后端的交互图: 代码实现: $.ajax({ type: "post", url: "http://localhost:8080/ccnb/user/login", data: { "telephone": login_name,

随机推荐