zoukankan      html  css  js  c++  java
  • ajax实例二:发送post请求

    第二例:发送POST请求(如果发送请求时需要带有参数,一般都用POST请求)

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

    -------------------------------------------------------------------------------------------

    <%@ 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("POST", "<c:url value='/AServlet'/>", true);
    xmlHttp.setRequestHeader("Content-Type", "application/x-www-form-urlencoded");
    /*
    3. 发送请求
    */
    xmlHttp.send("username=222&password=234");//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>

  • 相关阅读:
    [转]移动端实现垂直居中的几种方法
    MySQL常见的两种存储引擎:MyISAM与InnoDB的爱恨情仇
    关于分布式计算的一些概念
    一份最中肯的Java学习路线+资源分享(拒绝傻逼式分享)
    Java多线程学习(八)线程池与Executor 框架
    深入理解工厂模式
    深入理解单例模式
    Java NIO 之 Buffer(缓冲区)
    Java NIO 概览
    分布式系统的经典基础理论
  • 原文地址:https://www.cnblogs.com/danyuzhu11/p/6837136.html
Copyright © 2011-2022 走看看