写个例子,以备后用
一、JavaScript 解析返回的xml格式的数据:
1、javascript版本的ajax发送请求
(1)、创建XMLHttpRequest对象,这个对象就是ajax请求的核心,是ajax请求和响应的信息载体,单是不同浏览器创建方式不同
(2)、请求路径
(3)、使用open方法绑定发送请求
(4)、使用send() 方法发送请求
(5)、获取服务器返回的字符串 xmlhttpRequest.responseText;
(6)、获取服务端返回的值,以xml对象的形式存储 xmlhttpRequest.responseXML;
(7)、使用W3C DOM节点树方法和属性对该XML文档对象进行检查和解析。
2、 实例:
(1)、发送ajax请求,以及解析返回的数据
<script type="text/javascript"> /* js版本发送ajax请求 */ function tellxml(){ // 创建对象,适合于firefox 和safari var xmlhttpRequest= new XMLHttpRequest(); // 创建对象,适合于ie // var xmlhttpRequest=new ActiveXObject("Msxml2.XMLHTTP"); // 请求发送路径 url var url="http://localhost:18080/servlet/Servlet1?aa=10"; // Open方法绑定一个发送过程,但不发送数据。Open方法最后一个参数为true时表示异步,否则同步 xmlhttpRequest.open("POST",url,true); // Send方法就是发送请求数据 xmlhttpRequest.send(url); // readstate 就是一个xmlhttprequest 对象的一个属性,来记录服务器返回的状态 var readstate =xmlhttpRequest.readyState; alert("状态:"+readstate); // status 就是发送请求的状态,如果是200 则说明请求响应成功 var status=xmlhttpRequest.status; alert("请求发送结果"+status); // "responseText”是xmlhttpRequest的一个属性,来以字符串形式存储HTTP响应值;“responseXML”属性是以XML形式来记录HTTP响应的值。 var text= xmlhttpRequest.responseText; alert(text); // “responseXML”是xmlhttpRequest的一个属性,是以XML文档的对象来存储服务器端返回的值,可以使用W3C DOM节点树方法和属性对该XML文档对象进行检查和解析。 var xml= xmlhttpRequest.responseXML; var values=xml.getElementsByTagName("info"); alert("值"+values); alert("长度"+values.length); // 解析获取内容 for(var i=0;i<values.length;i++){ var name1=values[i].getElementsByTagName("name")[0].firstChild.data; alert(name1); } }; </script>
(2)、servlet 接受ajax 请求:
@Override protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { // TODO Auto-generated method stub String aaa= request.getParameter("aa"); System.out.print("ajax 数据:"+aaa); // 向客户端响应信息 response.setCharacterEncoding("GBK"); response.setContentType("text/xml"); PrintWriter out= response.getWriter(); out.print("<?xml version=\"1.0\" encoding=\"GBK\"?>"); out.println("<infos>"); out.println("<info>"); out.println("<name>"+"name1"+"</name>"); out.println("<age>"+12+"</age>"); out.println("<name>"+"name2"+"</name>"); out.println("<age>"+22+"</age>"); out.println("</info>"); out.println("<info>"); out.println("<name>"+"name11"+"</name>"); out.println("<age>"+112+"</age>"); out.println("<name>"+"name22"+"</name>"); out.println("<age>"+222+"</age>"); out.println("</info>"); out.println("</infos>"); }
二、JavaScript 解析返回的json格式的数据:注意这里获取的是responseText 而不是responseXML也就是字符串而不是xml对象,因为返回的是json
1、发送请求,并解析返回的json格式的数据(这里返回的是json 对象的格式)
<script type="text/javascript"> /* js 解析返回的格式为 json */ function telljson(){ // 创建 xmlhttpRequest 对象 var xmlhttpRequest= new XMLHttpRequest(); //请求URL var url="http://localhost:18080/servlet/Servlet3?aa=10"; // 将请求过程绑定到 open 方法 xmlhttpRequest.open("POST",url,true); // 发送请求 xmlhttpRequest.send(url); // readstate 就是一个xmlhttprequest 对象的一个属性用来记录服务端响应的状态 var readstate =xmlhttpRequest.readyState; alert("请求准备状态:"+readstate); // status 服务器执行的状态 var status=xmlhttpRequest.status; alert("请求发送结果"+status); // responseText 对象为xmlhttpRequest 对象的一个属性,用来以字符串的方式存储服务器端返回的值。 var text= xmlhttpRequest.responseText; alert("json text: "+text); // 获取json 返回值 // 那边传的是json对象的格式的一个字符串,在前台首先将字符串转化为一个json格式的js对象 var json= eval("("+text+")"); // 通过eval() 方法将json格式的字符串转化为js对象,并进行解析获取内容 alert("age:"+json.age+"age1:"+json.age1); }; </script>
2、servlet 接受请求,并返回数据