zoukankan      html  css  js  c++  java
  • 类似公司框架  Ajax与se…

    http://www.cnblogs.com/yidong/archive/2009/08/21/1551208.html

     

     

    Ajax与servlet交互的实例

    1.JavaScript部分
    复制代码
    var req;
     

     var url;
     function getResult()
      
       var f
    =document.getElementByIdx_x("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"); 
      }
     }
     

     function complete(){
      
    if (req.readyState == 4)
      {
        
    if (req.status == 200)
        {
          var items
    =document.getElementByIdx_x("belong");
        //以下为解析返回的XML文档  
          var xmlDoc 
    = req.responseXML;
          var Node
    =xmlDoc.getElementsByTagName_r("type_name");
          
    //var str=new Array();
           var str=null;
           
    //清空工作
            items.innerHTML=""; //删除一个 select内的全部内容
      for(var i=0;i<</SPAN>Node.length;i++)
           {

              str=Node[i];
              
    //alert(str.childNodes[0].nodeValue);
              var objectOption=document.createElement_x("option");
               items.options.add(objectOption);
              //firfox不支持innerText必须用textContent代替
               
    if (window.ActiveXObject)
               {objectOption.innerText
    =str.childNodes[0].nodeValue;}
               
    else
               {objectOption.textContent
    =str.childNodes[0].nodeValue;}
           }
         }
       }
      }
    复制代码
    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(
    "");
         
    while(rs.next())
          {
               
          sb.append(
    ""+rs.getString(1)+"");
             
          }
            
    //sb.append(""+action+"");
            sb.append(""); 
            out.write(sb.toString());//注意这里向jsp输出的流,在script中的截获方法
            out.close();
            stmt.close();
            con.close();
        }
        
    catch(Exception ex)
        {
             
        }
      
     }
    }
  • 相关阅读:
    Javascript正则表达式详解转载
    转载Sqlserver2005 存储过程分页
    转载手把手教你用C#打包应用程序
    学习内容
    用C#实现将HTML文件转换为CHM文件(转)
    C# Windows服务添加安装程序
    sql 2008评估期已过有关如何升级,企业试用版到期,升级为企业版+sql2008破解
    iis不能启动是什么原因?错误提示:“提示服务器没有及时相应启动或控制请求”
    .NET 获取数据库中所有表名的方法
    如何获取Dynamics当前登录的用户的GUID,进而获取用户的信息
  • 原文地址:https://www.cnblogs.com/wangduqiang/p/4180858.html
Copyright © 2011-2022 走看看