JavaWeb笔记-23-ajax发送请求的三则示例(发送get、发送post、响应xml、)

版权声明:转载请联系作者本人!!! https://blog.csdn.net/qq_41307491/article/details/82356745

一、发送get请求案例


<script type="text/javascript">

//创建XMLHttpRequest对象的函数 
function createXMLHttpRequest() {
    try {
        return new XMLHttpRequest();
    } catch(e) {
        try {
            return new ActiveXObject("Msxml2.XMLHTTP");
        } catch(e) {
            try {
                return new ActiveXObject("Microsoft.XMLHTTP");
            } catch(e) {
                alert("哥们儿,你用的是什么浏览器啊?");
                throw e;
            }
        }
    }
}


 window.onload = function(){  //文档加载完毕后执行的代码

        var btn = document.getElementById("btn");  //得到按
        btn.onclick = function(){  //给按钮的点击事件注册监听
            //ajax四步操作,得到服务器响应。  把响应结果显示到h1元素中

            //1.得到异步对象
            var xmlHttp = createXMLHttpRequest();

            //2.打开与服务器的连接
            xmlHttp.open("GET", "<c:url value='/AServlet'/>", true);

            //3.发送请求
            xmlHttp.send(null);  //GET请求没有请求体,需要给出null

            //4.注册监听器
            xmlHttp.onreadystatechange = function(){ //当xmlHttp的状态发生改变时执行
                //双重判断:判断是否为4状态(服务器响应结束),判断是否为200(响应成功)
                if(xmlHttp.readyState == 4 && xmlHttp.status == 200) {
                    // 获取服务器的响应内容
                    var text = xmlHttp.responseText;

                    //获取h1元素
                    var h1 = document.getElementById("h1");

                    //添加响应内容到h1元素。
                    h1.innerHTML = text;
                }
            };  
        };
    };
</script>

  </head>

<!-- 得到服务器的响应并显示 --> 
  <body>
 <button id="btn">点击这里</button>
    <h1 id="h1"></h1>
  </body>
</html>

二、发送POST请求


应用:如果发送请求时需要带有参数,一般都用POST请求

1)open: 打开与服务器的连接 
      xmlHttp.open("POST","URL",是否异步)
2)设置Content-Type请求头:
      xmlHttp.setRequestHeader("Content-Type", "application/x-www-form-urlencoded");
3)send: 发送请求时指定请求体
      xmlHttp.send("username=zhangSan&password=123");

三、响应内容为xml数据案例


    响应内容为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;
            }
        };
    };
};

//servlet代码
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);
    }
}

猜你喜欢

转载自blog.csdn.net/qq_41307491/article/details/82356745