• Ajax发送GET、POST请求和响应XML数据案例


    1、新建工程

      新建一个java web工程,新建一个Servlet文件 AServlet.java,用于返回get和post请求。

    public class AServlet extends HttpServlet {
    
        public void doGet(HttpServletRequest request, HttpServletResponse response)
                throws ServletException, IOException {
            System.out.println("Hello AJAX!");
            response.getWriter().print("Hello AJAX!!!");
        }
        
        public void doPost(HttpServletRequest request, HttpServletResponse response)
                throws ServletException, IOException {
            response.setContentType("text/html;charset=utf-8");
            request.setCharacterEncoding("UTF-8");
            
            String username = request.getParameter("username");//获取请求参数
            System.out.println("(POST:) Hello AJAX!" + username);
            response.getWriter().print("(POST:) Hello AJAX!!!" + username);
        }
    }

      新建一个Servlet文件 BServlet.java,用于返回xml数据。

    public class BServlet extends HttpServlet {
        public void doGet(HttpServletRequest request, HttpServletResponse response)
                throws ServletException, IOException {
            String xml = "<students>" +
                "<student number='ITCAST_1001'>" +
                "<name>zhangSan</name>" +
                "<age>18</age>" + 
                "<sex>male</sex>" +
                "</student>" +
                "</students>";
            
            response.setContentType("text/xml;charset=utf-8");
            response.getWriter().print(xml);
        }
    }

    2、GET请求案例

    <%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%>
    <%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %>
    
    
    <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
    <html>
      <head>
        <title>My JSP 'ajax1.jsp' starting page</title>
        
        <meta http-equiv="pragma" content="no-cache">
        <meta http-equiv="cache-control" content="no-cache">
        <meta http-equiv="expires" content="0">    
        <meta http-equiv="keywords" content="keyword1,keyword2,keyword3">
        <meta http-equiv="description" content="This is my page">
        <!--
        <link rel="stylesheet" type="text/css" href="styles.css">
        -->
    <script type="text/javascript">
    // 创建异步对象
    function createXMLHttpRequest() {
        try {
            return new XMLHttpRequest();//大多数浏览器
        } catch (e) {
            try {
                return ActvieXObject("Msxml2.XMLHTTP");//IE6.0
            } catch (e) {
                try {
                    return ActvieXObject("Microsoft.XMLHTTP");//IE5.5及更早版本    
                } catch (e) {
                    alert("哥们儿,您用的是什么浏览器啊?");
                    throw e;
                }
            }
        }
    }
    
    window.onload = function() {//文档加载完毕后执行
        var btn = document.getElementById("btn");
        btn.onclick = function() {//给按钮的点击事件注册监听
            /*
            ajax四步操作,得到服务器的响应
            把响应结果显示到h1元素中
            */
            /*
            1. 得到异步对象 
            */
            var xmlHttp = createXMLHttpRequest();
            /*
            2. 打开与服务器的连接
              * 指定请求方式
              * 指定请求的URL
              * 指定是否为异步请求
            */
            xmlHttp.open("GET", "<c:url value='/AServlet'/>", true);
            /*
            3. 发送请求
            */
            xmlHttp.send(null);//GET请求没有请求体,但也要给出null,不然FireFox可能会不能发送!
            /*
            4. 给异步对象的onreadystatechange事件注册监听器
            */
            xmlHttp.onreadystatechange = function() {//当xmlHttp的状态发生变化时执行
                // 双重判断:xmlHttp的状态为4(服务器响应结束),以及服务器响应的状态码为200(响应成功)
                if(xmlHttp.readyState == 4 && xmlHttp.status == 200) {
                    // 获取服务器的响应结束
                    var text = xmlHttp.responseText;
                    // 获取h1元素
                    var h1 = document.getElementById("h1");
                    h1.innerHTML = text;
                }
            };
        };
    };
    </script>
      </head>
      
      <body>
    <button id="btn">点击这里</button>
    <h1 id="h1"></h1>
      </body>
    </html>
    GET请求案例JSP代码

    3、POST请求案例

    * open:xmlHttp.open("POST" ....);
    * 添加一步:设置Content-Type请求头:
      xmlHttp.setRequestHeader("Content-Type", "application/x-www-form-urlencoded");
    * send:xmlHttp.send("username=zhangSan&password=123");//发送请求时指定请求体

    window.onload = function() {//文档加载完毕后执行
        var btn = document.getElementById("btn");
        btn.onclick = function() {//给按钮的点击事件注册监听
            /*
            ajax四步操作,得到服务器的响应
            把响应结果显示到h1元素中
            */
            /*
            1. 得到异步对象 
            */
            var xmlHttp = createXMLHttpRequest();
            /*
            2. 打开与服务器的连接
              * 指定请求方式
              * 指定请求的URL
              * 指定是否为异步请求
            */
            /************修改open方法,指定请求方式为POST**************/
            xmlHttp.open("POSt", "<c:url value='/AServlet'/>", true);
            /************设置请求头:Content-Type************/
            xmlHttp.setRequestHeader("Content-Type", "application/x-www-form-urlencoded");
            /*
            3. 发送请求
            */
            /**********发送时指定请求体***********/
            xmlHttp.send("username=张三&password=123");//GET请求没有请求体,但也要给出null,不然FireFox可能会不能发送!
            /*
            4. 给异步对象的onreadystatechange事件注册监听器
            */
            xmlHttp.onreadystatechange = function() {//当xmlHttp的状态发生变化时执行
                // 双重判断:xmlHttp的状态为4(服务器响应结束),以及服务器响应的状态码为200(响应成功)
                if(xmlHttp.readyState == 4 && xmlHttp.status == 200) {
                    // 获取服务器的响应结束
                    var text = xmlHttp.responseText;
                    // 获取h1元素
                    var h1 = document.getElementById("h1");
                    h1.innerHTML = text;
                }
            };
        };
    };
    POST请求js代码

    4、响应Xml数据

    * 服务器端:
      设置响应头:ContentType,其值为:text/xml;charset=utf-8
    * 客户端:
      var doc = xmlHttp.responseXML;//得到的是Document对象!

    window.onload = function() {//文档加载完毕后执行
        var btn = document.getElementById("btn");
        btn.onclick = function() {//给按钮的点击事件注册监听
            /*
            ajax四步操作,得到服务器的响应
            把响应结果显示到h1元素中
            */
            /*
            1. 得到异步对象 
            */
            var xmlHttp = createXMLHttpRequest();
            /*
            2. 打开与服务器的连接
              * 指定请求方式
              * 指定请求的URL
              * 指定是否为异步请求
            */
            xmlHttp.open("GET", "<c:url value='/BServlet'/>", true);
            /*
            3. 发送请求
            */
            xmlHttp.send(null);//GET请求没有请求体,但也要给出null,不然FireFox可能会不能发送!
            /*
            4. 给异步对象的onreadystatechange事件注册监听器
            */
            xmlHttp.onreadystatechange = function() {//当xmlHttp的状态发生变化时执行
                // 双重判断:xmlHttp的状态为4(服务器响应结束),以及服务器响应的状态码为200(响应成功)
                if(xmlHttp.readyState == 4 && xmlHttp.status == 200) {
                    // 获取服务器的响应结果(xml)
                    var doc = xmlHttp.responseXML;
                    // 查询文档下名为student的所有元素,得到数组,再取下标0元素
                    var ele = doc.getElementsByTagName("student")[0];
                    var number = ele.getAttribute("number");//获取元素名为number的属性值
                    var name;
                    var age;
                    var sex;
                    
                    // 处理浏览器的差异
                    if(window.addEventListener) {
                        name = ele.getElementsByTagName("name")[0].textContent;//其他浏览器
                    } else {
                        name = ele.getElementsByTagName("name")[0].text;//IE支持
                    }
                    if(window.addEventListener) {
                        age = ele.getElementsByTagName("age")[0].textContent;//其他浏览器
                    } else {
                        age = ele.getElementsByTagName("age")[0].text;//IE支持
                    }
                    if(window.addEventListener) {
                        sex = ele.getElementsByTagName("sex")[0].textContent;//其他浏览器
                    } else {
                        sex = ele.getElementsByTagName("sex")[0].text;//IE支持
                    }
    
                    var text = number + ", " + name + ", " + age + ", " + sex;
                    document.getElementById("h1").innerHTML = text;
                }
            };
        };
    };
  • 相关阅读:
    HDU 1018 Big Number
    UVa 10603 倒水问题
    UVa 12108 特别困的学生
    UVa 1590 IP网络(简单位运算)
    UVa 12325 宝箱
    UVa 253 骰子涂色
    UVa 815 洪水!
    springmvc(2)处理器设配器和映射器
    SpringMVC(1)
    MyBatis(10)逆向工程
  • 原文地址:https://www.cnblogs.com/hehaiyang/p/4708274.html
Copyright © 2020-2023  润新知