Ajax与servlet交互的实例【转】
来源:互联网 发布:windows sublime git 编辑:程序博客网 时间:2024/05/22 02:16
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) { } }}
原文章:Ajax与servlet交互的实例
- Ajax与servlet交互的实例【转】
- Ajax与servlet交互的实例
- Ajax与servlet交互的实例
- ajax与servlet交互实例,初学者看
- Ajax与Servlet的数据交互
- ajax与servlet的动态交互
- ajax与servlet之间的交互方式
- appcan与.net的Ajax交互实例
- Ajax与Json交互实例
- 新手笔记:easyUI 的ajax方式与servlet交互问题
- 06-ajax与页面和servlet的数据交互
- (二)jQuery+ajax与servlet的交互
- AJAX+ASP交互的实例
- Flex与Java Servlet交互实例
- json在servlet与ajax之间的传递实例
- Spring MVC与Ajax交互实例
- Ajax与后台交互小实例
- servlet与applet的交互
- 【转】国内HTML5前端开发框架汇总
- JBoss 系列三十六:jBPM5示例之 Email
- WebGL学习随手记(一)
- JS 判断对象类型
- iOS应用开发规划
- Ajax与servlet交互的实例【转】
- 金文学何许人也的即时通讯
- Servlet 学习总结
- nodeType 用法
- HTML+CSS+JavaScript 学习记录
- 一个大牛的系列文章:An intro to modern OpenGL. Chapter 2.2: Shaders
- 自定义函数--获取文件的根目录
- WebSocket 学习概要
- Tomcat 之 Catalina