一、 HTTP 请求和响应

一个HTTP请求由4部分组成

  • HTTP请求方法(也叫动作Verb)
  • 正在请求的URL
  • 一个可选的请求头集合(可能包含身份验证信息等)
  • 一个可选的请求主体

服务器返回的HTTP响应由3部分组成

  • 一个数字和文字组成的状态码,用来显示请求的成功和失败
  • 一个响应头集合
  • 响应主体

说明:

  1. XMLHttpRequest不是协议级的HTTP API而是浏览器级的API,浏览器级的API需要考虑Cookie、重定向、缓存和代理,而协议级的API只需要考虑请求和响应
  2. XMLHttpRequest和本地文件: XMLHttpRequest针对的是HTTP协议,即URL不能是file://,所以测试的时候必须将文件上传到Web服务器或运行一个本地服务器
  3. 同源策略问题(same-origin policy),所以测试的时候必须将文件上传到Web服务器或运行一个本地服务器

二、  使用XMLHttpRequest对象

1、 实例化XMLHttpRequest对象

var request = new XMLHttpRequest();
// Emulate the XMLHttpRequest() constructor in IE5 and IE6
if (window.XMLHttpRequest === undefined) {
  window.XMLHttpRequest = function() {
   try {
  // Use the latest version of the ActiveX object if available
  return new ActiveXObject("Msxml2.XMLHTTP.6.0");
   }catch (e1) {
  try {
      // Otherwise fall back on an older version
      return new ActiveXObject("Msxml2.XMLHTTP.3.0");
    } catch(e2) {
      // Otherwise, throw an error
       throw new Error("XMLHttpRequest is not supported");
    }
  }
};
}

说明: 在IE5和IE6中的XMLHttpRequest只是一个ActiveX对象,IE7之前的版本不支持非标准的XMLHttpRequest() 构造函数

 2、  简单的指定请求和发送请求步骤

如用POST方法发送纯文本给服务器请求完成

function postMessage(msg) {
  var request = new XMLHttpRequest(); // ①New request
  request.open("POST", "/log.php"); // ②POST to a server-side script
  // Send the message, in plain-text, as the request body
  request.setRequestHeader("Content-Type", "text/plain;charset=UTF-8"); //③Request body will be plain text
  request.send(msg); // ④Send msg as the request body
  // The request is done. We ignore any response or any error.
}

说明:

2.1)指定请求——XMLHttpRequest的open()方法

Request.open(“方法”,”URL”);

2.2)设置请求头——XMLHttpRequest的setRequestHeader()方法

request.setRequestHeader("Content-Type", "text/plain");

 说明:

  • 如果对相同的头调用setRequestHeader多次,新值不会取代旧值,反之,HTTP请求将包含这个头的多个副本或这个头将指定多个值
  • 不能指定的头信息的值包括(XMLHttpRequest将自动添加这些头而防止伪造它们), 能指定“Authorization”,但通常不需要这么做,一般会通过open()的可选的第三参数来设置用户名和密码

aaarticlea/png;base64,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" alt="" />

2.3)发出请求——XMLHttpRequest的send()方法

request.send(参数);

  • GET请求没有主体,应传递null或省略这个参数
  • POST请求通常拥有主体,并应匹配使用setRequestHeader()指定的“Content-Type”头

2.4)请求的顺序问题——所以上面的三个方法的顺序不能错,否则将抛出异常

  • 请求方法和URL首先到达
  • 请求头
  • 请求主体

3、取得响应

上面的例子中忽略了任何响应和任何错误,只管发送,下面我们开始讨论如何取得响应并根据响应进行处理。

如下例——如果①请求完成,②请求成功且③响应主体是文本,才会把响应主体发送给指定的回调函数

// Issue an HTTP GET request for the contents of the specified URL.
// When the response arrives successfully, verify that it is plain text
// and if so, pass it to the specified callback function
function getText(url, callback) {
  var request = new XMLHttpRequest(); // ①Create new request
  request.open("GET", url); // ② Specify URL to fetch
  request.onreadystatechange = function() { // ③Define event listener
    // If the request is compete and was successful
    if (request.readyState === 4 && request.status === 200) {
    var type = request.getResponseHeader("Content-Type");
    if (type.match(/^text/)) // Make sure response is text
      callback(request.responseText); // Pass it to callback
    }
  };
  request.send(null); // ④Send the request now
}

3.1)readystatechange事件

理论上,每次readyState属性改变均会触发readystatechange事件。实际中

3.2)readyState

理论上,每次readyState属性改变均会触发readystatechange事件。但实际中

  • readyStart为0和1时候可能没触发该事件
  • 调用send()时候,即使readyState仍处于OPENED状态,也触发该事件
  • 某些浏览器在LOADING状态时也触发该事件
  • 当readyState变为4或服务器的响应完成时,所有浏览器均触发该事件

在老的浏览器和IE8中没有定义readyState的常量部分,这个时候应使用编码值进行处理。

3.3)getResponseHeader(),getAllResponseHeader()——查询响应头

说明:XMLHttpRequest会自动处理cookie,所以getResponseHeader()取得的”Set-Cookie”和”Set-Cookie2”则返回null

aaarticlea/png;base64,iVBORw0KGgoAAAANSUhEUgAAAe8AAACMCAIAAADa/LbaAAAWgElEQVR4nO2drRL0thWGDcNKM8XFLWtnDDq5h9yDJzMF5cWdCWsNcgHhKfZddD4U5Aso/GCgC9a2zr/kn921te+Ddr22fo6k10fHXqmZAAAA3J/m3QUAAABwAlBzAACoAag5AADUANQcAABqAGoOAAA1ADUHAIAagJoDAEANQM0BAKAGoOYAAFADUHMAAKgBqDnYydA1TdN0A/22fj0p9bYfp2maxr49NfGqmVtiNt2ZJ4OLcz81n0d20/YjHeXegJ+7qwW68BG4mKcjm5pgYes10HUHareskTad/BhgGDNXhqj5IpM3ULqlZw2LhDNPjvEhak4ab67WWnF3nC5n7LLDI8NuCCzMMqZikL8JDx0tlr5xvIxUOWKlZOwzu9DQHUxwKRaxq2+0DSev5k/tgMnSJVnUnMkhH0vHGPv2SGLi8gI3T+RmKoEv/jdGVWrocuNtv781m7WzxM4c67QdSEnNEiyNzvwLp32fztrl1mzXYp1bkCNq7ljKNtimkyfaRuunKgfQ/XmouRxTY9+e1FIH52fy8kyPN3L7EN980ho69m3OedrdOkTM29bTBh2FKXPN13NV8d4hIkO33LSSr9N23VXCDtlbCz1h08nyaNuPywC8TvUBpZmmeN5kxNZS5HqQjc9v+2Kgd4NIT14lEhQ+xDqrnzuTRvSy7Y78veHNyMXcMrv2uoTdxRPO9RBtmLbv8xLLWpJqozFzIvGfq/jmLJI3dE03OPcZZrUtXZ3ZPBhfuk/PuYV93YpjFZ+cLmB+gnMmeCfNNAUuTwqO8hZ0nkTK2fTaM1lfprPtpUM4CTrOo+5NnpO5dVJ5b6TlmHV9s1OPWXnPtA+wmdF63NcG/kbKok6OM59E7SH3V/LNV4Xt+odZjW4tTLSzq/Pbpfmk37sNikKXd/KCk0kNz399CZxFqOasy3ijPX424s7lrfGge3+o5p56FJxZ2tFvBvO1zdpZZg/VnPYBekpS9nVwD90sd8xfp48MhyRxBKVMA1PzNzfbQ81JNYSu+iZa2NLVDdcpnZMZGPy2mrHSppNpKeayVTd2aiCMtFhvFEe9jaRlaQT/nfWibWo+icR8LyGWq/p65HJfHqSYR2YvUHOG7Y97ap7KRSIHTEla2YhczS/hm09cxQw1lyba19XD8RX45pHbouy16WTzovpGThU8noLKUTJ7doaah775SvqdD0hXpzeoeSYaHolYcc+9L3NLtkzMM2Yv9s0XWGB96NwHoULNm3SRTk2V92K+OX+9yvXNeR22d/WMt8QfQKg5cOG7W5tOVmdUOW7qYH5Dkbfv+oaieq2MR0JFbxv7VnVwqgs9eUgp5msFXXzovXmtP8nNPgetr1/OVaYVI4Yxza7v0DQyqm7pahY2v9vS9938IDr2zcVLN4a0XNI3Z7hOynJBzua7Iy1O5Z+v5ltDM+D1pH8PhfNC51i7vHnaNPMkW6ewnkCe1jfrgKcPelSCg7icpMfVnOS8drPYLSfU9TTHD9zGZp/oeF3eI2c6vxqLuOazvgxJzftx6KJ/c1GsF0HEcY9XqYlxc6Tls4aJ9KKLujrpweSzGA66S8vXTMpstTHSwh8Z0PpD06/F/f7ZT8nGzcEzGRdXmzuN6ga8FfbuDFgYOmZTGvl5im8+Gj6STgVNdR3ureYAfA5CzcVXAKDmANwFEYKCTwwYUHMAAKgBqDkAANQA1BwAAGoAag4AADUANQcAgBqAmgMAQA1AzQEAoAag5gAAUANQcwAAqAGoOQAA1ADUHAAAagBqDgAANQA1BwCAGoCaAwBADUDNAQCgBqDmAABQA1BzAACoAag5AADUQDNNaYOqeWeqZftWuj/7uv/gcu5yINqtnG95FSZlbyOOrbLOAFusX5hH43SdvR/zNC1D4wptN5f1AluRUptsss91jPkMZt986FgrjX0rRTcZYOzb9Qu5jl4zdNRgQ7d88ZNarx77dj6BJwL2kew59u01hiJYGDoxGpwGev1QcHJkwvBeaAk32eeIMS+uSa6ap0IPXdsPpBXJj7xxh85W84Sf1Nh3SdbnY+kuAPZCzKlaGbwZNUxYa0UnPhuvIB+u5p5ZrkKRmjfdQM6QvrlRvWSwsW9JulFSKetLG+xmsIaFbXexRqqaNH1smrYfRYSSn8zno92gAo3WzdW53z7Gkwxy8rKxVlYHg2KoCvKoJyvOrOZhSXZaQ+TCrzOq6at5piQtGwRLXkYwWKQTmOUqFKt5kgIuwXOVeeVI92A/xUktWUNxToNbE7bdDrEZiYTQCDLxaNjEcjU1idXKqZLV+201X7Kj/tM8nCY6fkkK6eeoGGYFI9+8oTc1EmZVFd9mDZbFatm2H81qumruloSmwTJlpVgVKVejS1Ku5utJhgTLeHjsm4dJXd1g9wJqfhBusnWYMCFejzpa7T1RctQ8nOs6gQKu4b7Hq4thV7As0rKmYlZ8ozViC0RVcKtjlsTIlBxZort24a8+gLao+VytQUvwkgRxGpy4eTapqxvsZiDScgwuX+s31sHpVLNhKHf5bDWPoipS03011xUsVnMaexIV32gNM4egmr6amyUx7kHavsn3tAt/9QG0Tc0f1WlbeSdbzrPVPNkoSGqihy9ssJuBp6DH2OybG/Z9lpqLEI/MWbb2k31zU4I3WMO1gFNNX83NkkS+eXowQSMuRuGvLk7Lv4dYNEk9VODBEv5Mg1jXbiVyawiSmtLZlzbY3Uj2hGX3QEKuIm5uDAIRjyaqu0HN3aeg4rMMeD8+pyEm03KK4VfwIeudjDE7ldUV32YNWkzqLQ5mNUvi5ilTcUOwQ1XctYwLL8xyFdJ/Qe1J23LUCb7Si1j34LB5aBDHTZfChTwNGHUnX3/7+vW3r7P9vmmab+bO+vW3r7/80LRt2zyO//XHcT3/1x9nY3/z5x9//TpN0zR0j2u7gX+epl9+aJoffmF5WbOntf0eD5pIU5KXLvrFM6IvIFivnMzFoL+TAcu9dO1sjX3b9evp9MfROqoPBsUwklLvlizV9G3ilESmYWbKj0XpXNQrwj/7AbD58r8v3/383UNnv/v5O/r5j/9o/vzv/+rj2z7/6/fN3//w3+X4l/99wfTpbVTx5xaoOQAuD0F/SC39/NPfmt/98y/6+MbPP33/bUoHzzXewSNmwl+9uy1QcwAiHvrLPj+m29823//ni3tO4eex/9O3TfPt98E6LeCZjOQN+tsDNQcAgBqAmgMAQA1AzQEAoAag5gAAUANQcwAAqAGoOQAA1ADUHAAAagBqDgAANUDU3FyuwVnWMrsYC90iJB3IXSVzAWcx2ssYg3czvGaX5wEbNH8A1hqKYpkxud6avextyVbOmavYyq1ottOo6u9uVcH3waELFKrzDg8HZ3nGd5DdfKPkQqB5qLlc7Yf1K3st52hLCndX6PAqtfgaGu44c8teaCiDFTUWvFW3oOY7Tv5AHmqulvuh3Sqv5uOGrZyDq1hDYQWiM7nQUL4fZJFZEi9s77XL89IFwkR2VoSgw7VGCX01z5SkxRKTIc00mS6B7YNLn90MdA8lu0JbVyk1R8udBdR8L3JPCLrkttq5gpwsR016QLRvt4olO7FPRhqjeqM2vjcMjbc5m06YOxIVVIRlsRplXm1dlbBkowleEpoGNCGgTM0TZV42279kv2+OljsLqPlO7I3WnPmqo9X5/c+c7FayoQmu4WZT8y5g7WCUjm6sSFx4nb1dnXxJEGnJsKp5YaSFEBxnzTbsiJsj0nIuUPOdcMOt31hvpbPQhqHc5bPV3I6qDNYuz0rNndfMlnn1hoqYOQQl9NXcLIlxDwIm6SmompVFm/fp42PhVs7BVfIpKOTnNKDmO9nsmxtWfpaaixCPzFn4Q4Fvbkrwhoq4hXdK6Ku5WRL45qXQNxRZRNx88MmQToKO5q0Je2rOr6ItjDDLqWCLsr0Qv0LEzenTQR2DJn27IGRMc3OfgorPMqL/+Dx4uzw7sXK7zNsqQopJrPKqDZrBSukuz9KKalpUtJVz7iqjAOAY0rSwbDFV7fI8jdVu0AwW8M9+AGywyzO4F1BzAFywyzO4EVBzACKwyzO4C1BzAACoAag5AADUANQcAABqAGoOAAA1ADUHAIAagJoDAEANQM0BAKAG0hqK5D+zy39p05oNAn/53AfBP/X3/bnfWYH/UI7617i+zEpqxYPVZl13sdULSMb4a8pW4qFxIMlTXi0/MSnNcMO/0R/8/9VT7fkC6KpbYq0sd/HxtJnn+r1ViwUFq2h5qcl18dn19lJCTo5yfR4vR28loqCEYn1IvtxFWp0oV8FXrSxG7IV1KfcRD429SZ7V9M9cVvB+K28eb5xbL9NI1JxWIlRzzti33aCtaKxwu2nBdFfBhy6v5rICdo5S3mzZjSvFpgDbL39pz8EqILuIh8YZSV4kKcX91Pw4H6XmI9swKB1QRgh2n/BSc+WYr9DrUaTmNEd/XBaVkCcgEi65/NXrcnzi4DyBjJqTJf5GfVAtDt00an9LlcIS46ATfy/WOJRuGWoGCtVKh2qh1O6pW4laNXUSJwYgC/Sa2W2vrNc0N4Otb86x+qFqklWuDKVSyiVbQediLXVMLgm1KH85zzFwVQtKKL4z2d5w+Qu7zq29jjcSDQ3Sh5J5B2szTDoRpO1upkACuI8JI7kRD50hq+sCuUTYdBlM78MuACkFuRnooCQbAWFFnPEma+on3jCh8bPbXFmvae7HQd88fTUENFBzz3UVd1/OEK9MFFxu5hireZFzvR7wTsv75i/qOvDLdxNPyNiTENmYyeq8s5kaKA+z5nKncTRX835Nk0qpWPqmEpAhTjJNUJcUVCRbPLc8eqiWZVdUWa9pbsixuHmwFUJRpIXDuosfA8lKsL7c7UfZSEvm+NwTxD2u9PKXRVpu3UXfTUbNrQGgwyKOMHopWDdfe37qqrkZmkkK1jHn2R7DqtAiZkMvKahIsZqbiasAb9ZuhZX1muaG7FFzeqtzH/arS7xNqEZra1Am2uwdGt/a3uVujno6Qa7PlZBUrOvFw4Syy1/2jomYm4NtZNTcjAUrVzHyzY3G8adS0gOw1dwsQzqFjKho0hb45uqSgooUq7mZuHajsnYrq2ydvnnwGpa86a+t6ruaope5byiO7FUQ7vWQrqmnTwrvcj9HdhZt1JISpl+VwxRc7tnkacj+DV3fSjQ0aKeZG5ockp041+1GcwfO+Ttx+7Nq7pRhOaelzoddgPUnI1ZuX5KviCmUakiZ6VD3LD1JyNqtrLJe09yP3f8eWqPUanLZDfqSZFA7NV2G5YCcxTmmDi73ctTFSW5UUQlTCuFU8a3/HiIPEyLzAYd4aNATxI36caQn92x5WI8c6jTwxqLNKMRpOcZL6pRhiqMWeuL55K1EdU3zieswl5Xdpsp6TXM38M9+AACogZuquXA54XECAD6dm6o5AAAABtQcAABqAGoOAAA1ADUHAIAagJoDAEANQM0BAKAGoOYAAFADUHMAAKgBqDkAANSAuU4LhywwYv3n0lw2h2Es0sJXRKFLdblLUeAvnzvJtB8IMBbdaZqm7Yf+3tsBlzDsXbFk3GKcklWht5bkZStNl3CwMJuM6ayhyMpCl05T6e7Y4lmuSCfWBAoW0r1OG90FYs+brw/3FtZVm9Lie0vfvvXSqWVEq+XGlBunbFRvK8mllOJ4YcqN6axvPiPXFVZLco9Ht3geuoejQxZG48vTcTf9Mm10R/YPzo9l3eiAjIR5vWyoecDZxvnornuWmoeLD0+rvqqLg0129Nr/3UB+p2p+qVvs7fkA9Xkier+EZSsEHaMk66sKey8hAz59Ns6nEZ51tVuSnRhCPKbJc/GWo6ZTXicMN2toWEexQ82c1LJX8pIh+6Km5nqNW2fZ6SJr0zR9U7gL9xW3kRXDDArDosy8PGbi2ph5QjXXXVit1b8WR6q3UvNUX63mKScRGYD+nIBcih5sx1TzxaQyHGl39fXn7KbGxBNdt6mQGkW2V6A7LdAHUjJ9I9m4tGSLAW/ninSYnmAXUO2GwQtl1XpDSUj5qSdvm4L7j6LiRW1EizFcZePpI2o+Htviefkl9dCHF2KrubnYPdjA0MF8u/F8c/mZnecIpNzbRJ9vzEpZWuvveoysh40df+Kpti4tLyy72ahM1UErXbYnpMojmIuXlIQ3AlVzbQpxVFsl20b2TSBTGHYPMW4mduInRVpUmJxlI5/381nMpkhL+mUQT+3E2y3w1Y+A0NVutqi5NyqW38OdqkQAhL7uxQMx67A3dtpx1Fwlmymt0lCd+vrN0Vv6xXzupfOwfI6gJEb582qe9c2zbaQj+QWFIaZ4ysbTtpov91BLUElPEFEoL3+Wiq/mD7u2/CmoSAZadASEznezRc2jTmopRXB+GlZn+OYq2Uzu5/jm6RGD1fmsImivIyiJUf4CNadxc5lCURvlbwJB0Z+18bSp5txh5v4C8Zw991v19PgNRflkgrsgfCoANd+ICODBgDspVXM5e5XDMAx2LOcPxp7OdOyRREij8kCuIWFGsnFpnQi1namIlTNrjX1L3TTbIFatS0qiyy+qb/vmvkAWtZFoEBE3dwozl+FpG0/zfw9ZUy76o5gGGjO2rmyLZ9IVlH6zkqfE2n7EjvM7SD4IpHwnrHvzI53cXll0WZ7Q0hZ+F2eniSHXtvGGy0S110utz6wrBKWdxoJdni1vV++V7E0CssXbUBJpPa/6672HoGNRuTaawm5hFsYzhZl4YEwf/LMfgBtw7yhZ5Aq/Ax4SqCaGCzUH4AbcU80fT/vMx5/vRD/HvaFtDaDmAFyeu76fOwcRrldsHmm5Xvn2ATUHAIAagJoDAEANQM0BAKAGoOYAAFADUHMAAKgBqDkAANQA1BwAAGoAag4AADVgr9NirSqmlhJYDtK1ttIBY+2XOv5vdVfu+WfCN2P04uZTdnmeLrOE8vgZ1j6OtYaiseohWz1NrrPDBF4thJm+oTneh2hTUIax2ODSqz/h7ngRNZ8KrP0JzZHFXt+ciLZcxEAsVu7v0QwDX4eha/serbGdz97l+ULkrF3PWitH8PYeWu/K4WK/Q7BHs1jD/xq3+I/kIT9QnyN465tbC6iQxUzNFXHvssvzwFZita5l5uHJFJVKWC+oprmDEvU4G5FdUK96idRcrsBOfkoWW7YwafvRUHNlY/BqlggX1PwIppo3xOMx9k+wLJ50/Aa7PJMrrCKxOrEdkopK1Vj+olNNZz8Q5i/K4EJQr1o5Rc3XY/DNr0YaenNrYMePXZTuPcTOM4RELqVtn2/Eq1la6+9qy7FwJ7lwnp0prR9C16bZViq/EFxpQgvzLHP1qpVcpIWFyadpsiItKYEBcfNLYb2SgSbZwxY1ZwgFtNTcPH+4wC7PInlZJKdKW0vlS6/rhesyazWP6lUrwVNQufGf+olPusae79FspPkhNr0muLceYYuaR93cUvPg/OSdnuGbq2S3lpYXiZz0Yt9cl1mr+SeKTeEbisxlYD8Ro8m34OR9FmLyTqDmRyhVc3ai0edDLRwvtsszv5moItGzUtGW+GxpqZSam4GhrIXTDarrvQ2Xq6fo30P24+zlqB2uMib5n2LTC7K2xid6LIdJfVm94NFVvMtz9toSA+VKJVTErGaRhec0tf58kOzgn/0A3IAPmVp9SDWfBNQcgBvwITL3IdV8ElBzAC4PDVNUzIdU82n8HwHuFSa/yWXAAAAAAElFTkSuQmCC" alt="" />

3.4)同步响应Synchronous

XMLHttpRequest对象默认异步响应,如果先进行同步响应,设置open()的第三参数为false

// Issue a synchronous HTTP GET request for the contents of the specified URL.
// Return the response text or throw an error if the request was not successful
// or if the response was not text.
function getTextSync(url) {
  var request = new XMLHttpRequest(); // Create new request
  request.open("GET", url, false); // Pass false for synchronous
  request.send(null); // Send the request now
  // Throw an error if the request was not 200 OK
  if (request.status !== 200) throw new Error(request.statusText);
  // Throw an error if the type was wrong
  var type = request.getResponseHeader("Content-Type");
  if (!type.match(/^text/)) throw new Error("Expected textual response; got: " + type);
  return request.responseText;
}

3.5)响应解码——响应头主体类型

XMLHttpRequest对象的ResponseText, ResponseXML等属性可以得到响应主体的MIME类型,我们可以根据不同的类型分别将不同的对象发送给回调函数进行处理

// Issue an HTTP GET request for the contents of the specified URL.
// When the response arrives, pass it to the callback function as a
// parsed XML Document object, a JSON-parsed object, or a string.
function get(url, callback) {
  var request = new XMLHttpRequest(); // Create new request
  request.open("GET", url); // Specify URL to fetch
  request.onreadystatechange = function() { // Define event listener
  // If the request is compete and was successful
  if (request.readyState === 4 && request.status === 200) {
    // Get the type of the response
    var type = request.getResponseHeader("Content-Type");
    // Check type so we don't get HTML documents in the future
    if (type.indexOf("xml") !== -1 && request.responseXML){
      callback(request.responseXML); // XML response
    }else if (type === "application/json"){
      // JSON response, 先使用JSON.parse将对象转换为JSON对象
      callback(JSON.parse(request.responseText));
    }else{
      callback(request.responseText); // String response
    }
  };
  request.send(null); // Send the request now
}

说明:application/javascript或text/javascript响应类型情况下不需要使用XMLHttpRequest对象,以为<script>对象本身能操作HTTP来实现加载并执行脚本。

 4、请求主体编码(如何发送不同格式如form,JSON,XML,file,mulipart请求主体-数据到服务器)

4.1 Form-encoded request

HTML表单通过POST方法发送给服务器时候,对每个表单元素的名字和值执行普通的URL编码(使用16机制替换特殊字符),使用等号把编码的名字和值分开,并使用“&”分开名值对,如:

find=pizza&zipcode=02123&radius=1km

编码函数——将数据编码为名值对的形式

/*** Encode the properties of an object as if they were name/value pairs from  */
function encodeFormData(data) {
  if (!data) return ""; // Always return a string
  var pairs = []; // To hold name=value pairs
  for(var name in data) { // For each name
    if (!data.hasOwnProperty(name)) continue; // Skip inherited
    if (typeof data[name] === "function") continue; // Skip methods
    var value = data[name].toString(); // Value as string
    name = encodeURIComponent(name.replace(" ", "+")); // Encode name
    value = encodeURIComponent(value.replace(" ", "+")); // Encode value
    pairs.push(name + "=" + value); // Remember name=value pair
  }
  return pairs.join('&'); // Return joined pairs separated with &
}

HTTP POST request with form-encoded data

function postData(url, data, callback) {
  var request = new XMLHttpRequest();
  request.open("POST", url); // POST to the specified url
  request.onreadystatechange = function() { // Simple event handler
  if (request.readyState === 4 && callback) // When response is complete
    callback(request); // call the callback.
  };
  // Set Content-Type
  request.setRequestHeader("Content-Type", "application/x-www-form-urlencoded");
  request.send(encodeFormData(data)); // Send form-encoded data
}

GET request with form-encoded data ——适用于简单的只读查询情况

function getData(url, data, callback) {
  var request = new XMLHttpRequest();
  request.open("GET", url + "?" + encodeFormData(data)); // with encoded data added
  request.onreadystatechange = function() { // Simple event handler
    if (request.readyState === 4 && callback) callback(request);
  };
  request.send(null); // Send the request
}

4.2JSON-encoded request

function postJSON(url, data, callback) {
  var request = new XMLHttpRequest();
  request.open("POST", url); // POST to the specified url
  request.onreadystatechange = function() { // Simple event handler
  if (request.readyState === 4 && callback) // When response is complete
    callback(request); // call the callback.
  };
  request.setRequestHeader("Content-Type", "application/json");
  request.send(JSON.stringify(data));
}

4.3 XML-encoded request

// Encode what, where, and radius in an XML document and post them to the
// specified url, invoking callback when the response is received
function postQuery(url, what, where, radius, callback) {
  var request = new XMLHttpRequest();
  request.open("POST", url); // POST to the specified url
  request.onreadystatechange = function() { // Simple event handler
    if (request.readyState === 4 && callback) callback(request);
  };
  // Create an XML document with root element <query>
  var doc = document.implementation.createDocument("", "query", null);
  var query = doc.documentElement; // The <query> element
  var find = doc.createElement("find"); // Create a <find> element
  query.appendChild(find); // And add it to the <query>
  find.setAttribute("zipcode", where); // Set attributes on <find>
  find.setAttribute("radius", radius);
  find.appendChild(doc.createTextNode(what)); // And set content of <find>
  // Now send the XML-encoded data to the server.
  // Note that the Content-Type will be automatically set.
  request.send(doc);
}

4.4上传文件

// 查找有data-uploadto 属性的全部<input type="file"> 元素
// 并注册onchange handler 事件处理程序
//这样任何选择的文件都会自动通过POST方法发送到指定的 "uploadto" URL
// 服务器的响应是忽略的
whenReady(function() { // Run when the document is ready
  var elts = document.getElementsByTagName("input"); // All input elements
  for(var i = 0; i < elts.length; i++) { // Loop through them
    var input = elts[i];
    if (input.type !== "file") continue; // Skip all but file upload elts
    var url = input.getAttribute("data-uploadto"); // Get upload URL
    if (!url) continue; // Skip any without a url
    input.addEventListener("change", function() { // When user selects file
      var file = this.files[0]; // Assume a single file selection
      if (!file) return; // If no file, do nothing
      var xhr = new XMLHttpRequest(); // Create a new request
      xhr.open("POST", url); // POST to the URL
      xhr.send(file); // Send the file as body
    }, false);
  }
});

4.5 multipart/form-data request——当表单中同时包含文件上传和其他元素

function postFormData(url, data, callback) {
if (typeof FormData === "undefined") throw new Error("FormData is not implemented");
var request = new XMLHttpRequest(); // New HTTP request
request.open("POST", url); // POST to the specified url
request.onreadystatechange = function() { // A simple event handler.
if (request.readyState === 4 && callback) // When response is complete
callback(request); // ...call the callback.
};
var formdata = new FormData();
for(var name in data) {
if (!data.hasOwnProperty(name)) continue; // Skip inherited properties
var value = data[name];
if (typeof value === "function") continue; // Skip methods
// Each property becomes one "part" of the request.
// File objects are allowed here
formdata.append(name, value); // Add name/value as one part
}
// Send the name/value pairs in a multipart/form-data request body. Each
// pair is one part of the request. Note that send automatically sets
// the Content-Type header when you pass it a FormData object
request.send(formdata);
}

5、HTTP进度事件(略)

6、 中止请求和超时 (略)

三、  CORS(Cross-Origin Resource Sharing)——跨域资源共享

由于同源策略,默认情况下浏览器不容许XMLHttpRequest进行跨域请求

CORS是W3C的一个工作草案,其基本思想是使用自定义的HTTP头部让浏览器与服务器进行沟通,从而决定请求或响应是应该成功还是应该失败,如

  • Access-Control-Allow-Origin
  • Access-Control-Allow-Credentials (optional)

默认情况下CORS请求不能包含cookies,如果设置withCredentials为TRUE,就可以发凭据的请求了(详见下)

3.1  IECORS的实现

IE8引入了XDR(XDomainRequest)来实现安全可靠的跨域通信,其安全机制部分实现了CORS规范

3.2  其他浏览器对CORS的实现

Firefox 3.5+、Safari4+、Chrome和Android平台中的Webkit都通过XMLHttpRequest对象来实现对CORS的原生支持。

跨域XHR对象的安全限制有

  • 不能使用setRequestHeader()设置自定义头部
  • 不能发送和接受cookie
  • 调用getAllResponseHeader()方法总会返回空字符串

3.3  跨浏览器的CORS的实现

  • Preflightted请求——CORS通过一种叫做Preflightted Requests的透明服务器验证机制支持开发人员使用自定义的头部、Get或Post自我的方法,以及不同类型的主体内容。
  • 带凭据的请求——默认情况下,跨域请求不提供凭据(cookie、HTTP认证及客户端SSL证明等),通过设置withCredentials属性为true,可以指定某个请求应该发送凭证,如果服务器端接受了带凭据的请求,会用下面的HTTP头部来响应

Access-Control-Allow-Credentials: true

  • 跨浏览器的CORS

检查存在withCredential属性,再结合检测XDomainRequest对象是否存在,就可以兼顾所有浏览器了

function createCORSRequest(method, url){
  var xhr = new XMLHttpRequest();
  if (“withCredentials” in xhr){
  xhr.open(method, url, true);
  } else if (typeof XDomainRequest != “undefined”){
  xhr = new XDomainRequest();
  xhr.open(method, url);
  } else {
  xhr = null;
  }
  return xhr;
}
var request = createCORSRequest(“get”, “http://www.somewhere-else.com/page/”);
if (request){
    request.onload = function(){
  //do something with request.responseText
  };
  request.send();
}

XMLHttpRequest对象和XDomainRequest对象共同的属性/方法如下:

  • abort() — Use to stop a request that’s already in progress.
  • onerror — Use instead of onreadystatechange to detect errors.
  • onload — Use instead of onreadystatechange to detect successes.
  • responseText — Use to get contents of response.
  • send() — Use to send the request.

四、  其他跨域技术

4.1  JSONP——借助<script>请求发送HTTP请求

使用<script>元素作为Ajax传送的技术称为JSONP,适用于HTTP请求所得到的响应数据是JSON编码的情况下。

JSONP看起来与JSON差不多,只不过是被包含在函数调用中的JSON,如

callback({ “name”: “Nicholas” });

回调函数({数据});

其优点有:

  • 不受同源策略的影响
  • 包含JSON编码的响应数据会自动解码(即,执行),可直接用相应的方法读取处理数据
// Make a JSONP request to the specified URL and pass the parsed response data to the specified callback.
// Add a query parameter named "jsonp" to
// the URL to specify the name of the callback function for the request.
function getJSONP(url, callback) {
  // Create a unique callback name just for this request
  var cbnum = "cb" + getJSONP.counter++; // Increment counter each time
  var cbname = "getJSONP." + cbnum; // As a property of this function
  // Add the callback name to the url query string using form-encoding
  // We use the parameter name "jsonp". Some JSONP-enabled services
  // may require a different parameter name, such as "callback".
  if (url.indexOf("?") === -1) // URL doesn't already have a query section
   url += "?jsonp=" + cbname; // add parameter as the query section
  else // Otherwise,
  url += "&jsonp=" + cbname; // add it as a new parameter.
  // Create the script element that will send this request
  var script = document.createElement("script");
  // Define the callback function that will be invoked by the script
  getJSONP[cbnum] = function(response) {
  try {
  callback(response); // Handle the response data
  } finally { // Even if callback or response threw an error
  delete getJSONP[cbnum]; // Delete this function
  script.parentNode.removeChild(script); // Remove script
  }
};
// Now trigger the HTTP request
script.src = url; // Set script url
document.body.appendChild(script); // Add it to the document
}
getJSONP.counter = 0; // A counter we use to create unique callback names

简单一点的代码

Function loadJSON(url){
var script = document.createElement(“script”);
script.type = “text/javascript”;
script.src = url;
document.getElementsByTagName(“head”)[0].appendChild(script);
}

说明: 最近换工作,面试的时候才发现自己的javascript的基本功还是差啊,这是以前急功近利,很多知识没有顾及到,得补( ⊙ o ⊙ )啊!

参考: JavaScript权威指南(第6版).JavaScript:The.Definitive.Guide.David.Flanagan

HTTP脚本化——XMLHttpRequest对象的学习笔记的更多相关文章

  1. C++中临时对象的学习笔记

    http://www.cppblog.com/besterChen/category/9573.html 所属分类: C/C++/STL/boost  在函数调用的时候,无论是参数为对象还是返回一个对 ...

  2. windows内核对象管理学习笔记

    目前正在阅读毛老师的<windows内核情景分析>一书对象管理章节,作此笔记. Win内核中是使用对象概念来描述管理内核中使用到的数据结构.此对象(Object)均是由对象头(Object ...

  3. JavaScript权威设计--事件冒泡,捕获,事件句柄,事件源,事件对象(简要学习笔记十八)

    1.事件冒泡与事件捕获 2.事件与事件句柄   3.事件委托:利用事件的冒泡技术.子元素的事件最终会冒泡到父元素直到跟节点.事件监听会分析从子元素冒泡上来的事件. 事件委托的好处:     1.每个函 ...

  4. JavaScript权威设计--Window对象(简要学习笔记十三)

    1.Window对象是所有客户端JavaScript特性和API的主要接入点. Window对象中的一个重要属性是document,它引用Document对象. JavaScript程序可以通过Doc ...

  5. JavaScript权威设计--JavaScript对象(简要学习笔记八)

    1.属性的特性 一个属性包含一个名字和4个特性.4个特性:值,可写性,可枚举性,可配置性   2.对象的三个属性 一:原型属性 要想检测一个对象是否是另一个对象的原型,使用isPrototypeOf( ...

  6. JavaScript权威设计--JavaScript对象(简要学习笔记七)

    1.with语句 语法: width(object){ statement } with语句可用于临时扩展作用域链.作用域链可以按序检索的对象列表,通过它可以进行变量名解析. with将object添 ...

  7. JSP内置对象之request对象【学习笔记】

    request对象是JSP中重要的对象,每个request对象封装着一次用户的请求,并且所有的请求参数都被封装在request对象中,因此request对象是获取请求参数的重要途径. 一.获取请求头与 ...

  8. 《JS高程》对象&原型学习笔记

    ECMA-262 把对象定义为:”无序属性的集合,其属性可以包含基本值.对象或者函数.”可以把 ECMAScript 的对象想象成散列表:无非就是一组名值对,其中值可以是数据或函数.   6.1.理解 ...

  9. No1_8.类和对象2_Java学习笔记_对象

    对象 /**** * *一.对象 *1.概念:对象是由类抽象出来的,对象可以操作类的属性和方法解决问题,了解对象的创建.操作和消亡很必要: *2.对象的创建: * a. new操作符创建:每实例化一个 ...

随机推荐

  1. data-*属性——使用自定义属性的方式存储数据

    HTML5提供了data-*属性能存储页面或应用程序的私有自定义数据.只需在属性前加上data-前缀即可,值可以是任意字符串. 存储的(自定义)数据能够被页面的 JavaScript 中利用,以创建更 ...

  2. parseInt 的第二个参数

    ["1","2","3"].map(parseInt) //[1,NaN,NaN] ["1","2" ...

  3. 学习笔记day6:CSS3动画属性

    总结: 1: CSS动画:@keyframes  animation:ie10+:加-webkit前缀: animation 则是属于关键帧动画的范畴; 它本身被用来替代一些纯粹表现的javascri ...

  4. WCF入门教程(vs2010)

    这几天挺别人提起WCF,鄙人之前只知道WPF,对WCF这个东东不甚了解,经过查阅网上的资料略有所得,和大家交流一下. 首先WCF是什么? Windows Communication Foundatio ...

  5. Android Menu菜单使用

    如上图右上角,菜单选项的编辑,第一种代码实现方式如下: package com.example.menu; import android.os.Bundle; import android.app.A ...

  6. Python学习笔记10—几个名词概念

    循环(loop),指的是在满足条件的情况下,重复执行同一段代码.比如,while 语句. 迭代(iterate),指的是按照某种顺序逐个访问列表中的每一项.比如,for 语句. 递归(recursio ...

  7. python中super关键字的用法

    http://python.jobbole.com/86787/ class A: def __init__(self):    print "enter A"    print ...

  8. a链接onclick="window.location.href=在ie6上面无法执行解决

    <a href="javascript:void(0)" onclick="window.location.href=document.getElementById ...

  9. 静态库冲突的解决办法:duplicate symbol

    昨天在做微信sdk和xmpp的集成,发现各自单独集成没问题,一起集成却总报错,百度了好一会儿才知道,这应该是库冲突造成的问题 然后参考了很多文章,跟着敲敲一遍,却发现问题多多,最后主要综合结合了这两个 ...

  10. C# Web中Session的使用

    1. 关于使用之前要注意的: 在使用session之前,一定要注意继承自System.Web.UI.Page,或在使用session时加上System.Web.HttpContext.Current: ...