1、HTTP:

  • 定义:超文本传输协议 (HTTP-Hypertext transfer protocol) 是一种详细规定了浏览器和万维网服务器之间互相通信的规则,通过因特网传送万维网文档的数据传送协议。
  • 通信要求:在一台计算机上获取并显示存放在多台计算机里的文本、数据、图片和其他类型的文件。

2、原始的Web客户端与Ajax架构的脚本化HTTP

  • 原始:通过链接、提交表单、和输入url、window.location.href、formObj.submit()
  • 异步、局部刷新体验:Ajax(用脚本操纵HTTP请求的Web应用架构)

3、Ajax与Comet,前者主动从服务器拉数据,后者从服务器向客户端推送数据

4、XMLHttpRequest

  • 兼容Web,对各种文本文件即可操作,并非只有XML
  • 标准支持HTTP和HTTPS(存在一些实现了其他传输协议的非标准版本)
  • IE7+与其他主流浏览器被支持 (IE5、6如下添加支持,IE5、6下XMLHttpRequest是ActiveX对象)
(function initXHR() {
if (w.XMLHttpRequest === undefined) {
w.XMLHttpRequest = function () {
try {
// 如果可用,则使用ActiveX对象的最新版本
return new ActiveXObject('Msxml2.XMLHTTP.6.0');
// JavaScript权威指南
// return new ActiveXObject('Msxml2.XMLHTTP'); // 百度名片
} catch (e) {
try {
// 否则回退到较老版本
return new ActiveXObject('Msxml2.XMLHTTP.3.0');
// JavaScript权威指南
// return new ActiveXObject('Microsoft.XMLHTTP'); // 百度名片
} catch (e) {
// 否则抛错
throw new Error('XMLHttpRequest is not supported');
}
}
};
}
}());

5、Http请求和响应分解

  • 请求

    • type     请求的方式(get、post、put)
    • url      请求的url地址
    • header  请求头
    • body     请求主体
  • 响应
    • status   响应状态,由数字或字符串(404:'Not Found',200:'OK')
    • header  响应头
    • body     响应主体

* IE下可以用本地文件进行Http请求,同源策略下其他主流浏览器做了交叉访问限制

  • 方法调用的顺序

    • var request = new XMLHttpRequest();
    • request.open('GET', 'url', async, user, pwd);
    • request.setRequestHeader('Content-type', 'text/plain; charset=UTF-8');  // request.getRequestHeader('Content-Type');
    • request.send(null);
      // get
      // init
      var request = new XMLHttpRequest();
      // connect
      request.open('GET', url, async, user, pwd);
      // setHeader
      request.setHeader(key, value);
      // send
      request.send(null); // post
      var request = new XMLHttpRequest();
      // connect
      request.open('POST', url, async, user, pwd);
      // setHeader
      request.setHeader(key, value);
      // send
      request.send(JSON.stringify({data:'test'}));
  • 对请求主体的编码
    • 表单编码(即html中form表单提交中用到的编码,实际上是执行普通的URL编码,使用十六进制转义码替换特殊符号,常用浏览器全局方法encodeURIComponent(text)来编码,格式是:key=val1&key=val2)

      // 把JSON类型的对象解析成表单编码的字符串
      var encodeFormData = function (data) {
      if (!data) return '';
      var pairs = [
      ];
      for (var key in data) {
      // 跳过继承属性和方法
      if (!data.hasOwnProperty(key) || typeof data[key] === 'function') continue;
      var value = data[key].toString();
      // %20是' '(长度为1)的16进制转义符号,在某些(作者也不知道是哪些,有兴趣的自己去了解一下)服务器处理中会将'+'号和空格互换
      // 即decoding的时候把'+'号解析成空格,encoding的时候把空格转成'+'
      key = encodeURIComponent(key.replace(/%20/g, '+'));
      value = encodeURIComponent(value.replace(/%20/g, '+'));
      pairs.push(key + '=' + value);
      }
      return pairs.join('&');
      };
      var postData = function (url, data, callback) {
      var request = XMLHttpRequest();
      request.open('POST', url);
      request.onreadystatechange = function () {
      if (this.readyState === 4 && typeof callback === 'function') callback(this);
      };
      request.setRequestHeader('Content-Type', 'application/x-www-form-urlencoded');
      request.send(encodeFormData(data));
      };
  • 对响应的处理(onreadystatechange)
    • XMLHttpRequest.readyState

      • UNSENT                     0   初始化阶段,尚未调用open
      • OPENED                        1   Http已连接,已调用open
      • HEADERS_RECEIVED      2   接收到头信息
      • LOADING                   3   接收到响应主体
      • DONE                            4  响应完成
  • 指定资源解码类型 request.overrideMimeType('text/plain; charset=utf-8'); // 需要在send方法触发前指定,使用场景,当你比服务器更清楚返回值的类型的时候
  • 当响应返回的xhr.getResponseHeader('Content-Type')是xml或html类型的时候,可以通过下面的方法解析(目前只支持主流浏览器和IE10+的html解析),当前浏览器支持xmlHttpRequest.responseXML属性(即会自动把响应类型为xml的文档解析成dom),相信后续版本会实现html的解析(HTMLDocument对象与XML的DOM对象API不同)
    var parser = (function () {
    try {
    //Firefox, Mozilla, Opera, etc, IE9+(IE10+才支持html解析)
    parser = new DOMParser();
    return parser;
    } catch (e) {
    return null;
    }
    }());
    var xmlParse = function (text, type) {
    var xmlDoc = null;
    if (parser) {
    try {
    // 默认xml解析,当前主流浏览器和IE10+(包含)支持type为html的解析,解析成HTMLDocument对象
    xmlDoc = parser.parseFromString(text, 'text/' + (type || 'xml'));
    return xmlDoc;
    } catch (e) { }
    }
    try {
    //Internet Explorer(可能作者水平不够,用这个插件解析,只能解析XML,而且对象屏蔽属性,超难调试)
    xmlDoc = new ActiveXObject ("MSXML2.DOMDocument");
    var flag = xmlDoc.loadXML(text);
    // 解析成功 返回,否则返回未解析的文本
    if (flag) return xmlDoc;
    return text;
    } catch (e1) {
    alert(e1.message);
    }
    };

脚本化HTTP的更多相关文章

  1. 深入理解脚本化CSS系列第六篇——脚本化伪元素的6种方法

    × 目录 [1]动态样式 [2]CSS类[3]setAttribute()[4]CSSRule对象添加[5]空样式覆盖[6]CSSRule对象删除 前面的话 我们可以通过计算样式来读取伪元素的样式信息 ...

  2. 深入理解脚本化CSS系列第四篇——脚本化样式表

    × 目录 [1]CSSStyleSheet [2]CSSRule 前面的话 关于脚本化CSS,查询样式时,查询的是计算样式:设置单个样式时,设置的是行间样式:设置多个样式时,设置的是CSS类名.脚本化 ...

  3. 深入理解脚本化CSS系列第三篇——脚本化CSS类

    前面的话 在实际工作中,我们使用javascript操作CSS样式时,如果要改变大量样式,会使用脚本化CSS类的技术,本文将详细介绍脚本化CSS类 style 我们在改变元素的少部分样式时,一般会直接 ...

  4. 深入理解脚本化CSS系列第一篇——脚本化行内样式

    × 目录 [1]用法 [2]属性 [3]方法 前面的话 脚本化CSS,通俗点说,就是使用javascript来操作CSS.引入CSS有3种方式:外部样式,内部样式和行间样式.本文将主要介绍脚本化行间样 ...

  5. (转)mongodb常用命令脚本化-自动化运维

    mongodb常用命令脚本化-自动化运维 把一些运维中常用到的mongodb命令写成shell脚本,极大的方便了维护   1 设置副本集   #!/bin/bash#mongodb 进入client ...

  6. JavaScript 客户端JavaScript之脚本化HTTP(通过XMLHttpRequest)

    XMLHttpRequest对象的设计目的是为了处理由普通文本或XML组成的响应:但是,一个响应也可能是另外一种类型,如果用户代理(UA)支持这种内容类型的话.   大多数浏览的客户端JavaScri ...

  7. JavaScript 客户端JavaScript之 脚本化浏览器窗口

    1.计时器 客户端Javascript以全局函数setTimeOut().clearTimeOut().setInterval().clearInterval()提供这一功能.   前者是从运行的那一 ...

  8. JavaScript 客户端JavaScript之 脚本化文档

    客户端JavaScript的存在把静态HTML转变为交互式的Web应用程序,脚本化Web页面的内容正是JavaScript存在的理由.   一个文档对象模型或者说DOM就是一个API,它定义了如何访问 ...

  9. 权威指南之脚本化jquery

    jqury函数 jquery()($())有4种不同的调用方式 第一种是最常用的调用方式是传递css选择器(字符串)给$()方法.当通过这种方式调用时,$()方法会返回当前文档中匹配该选择器的元素集. ...

随机推荐

  1. CentOS6.5 PHP基础环境搭建 [个人整理-亲测可用]

    ** * CentOS6.5 搭建基础PHP环境(yum安装) * http://www.aiplaypc.com/160.html **   #安装需要的包,有依赖关系,自动帮你解决 yum ins ...

  2. php时间戳与时间转换

    PHP时间大的来分有两种,一是时间戳类型(1228348800),二是正常日期格式(2008-12-4) 所以存到数据库也有两种形式了(真正不止,我的应用就两种),时间戳类型我是保存为字符串的,这个是 ...

  3. 2016年的个人计划-xiangjiejie

    过去一年,开发了angularjs的wap项目,appwap社区,忙忙碌碌不停的做各种活动. 职业目标 今年,要多看书,别总是被懒癌缠身. 多学习,过去半年很少看技术文章了吧,养成定期看文章的好习惯, ...

  4. ubuntu12.04安装jdk-7u79-linux-i586.tar.gz

    第一步:下载jdk-7u79-linux-i586.tar.gz 1.wget -c http://download.oracle.com/otn-pub/java/jdk/7/jdk-7-linux ...

  5. ubuntu apache svn 参考

    Ubuntu下Subversion服务器的安装配置     本文涉及的范围 要通过 HTTP 协议访问 Subversion 文件仓库,需要安装并配置好 Web 服务器.Apache2 被证实可以很好 ...

  6. cf C. Valera and Elections

    http://codeforces.com/contest/369/problem/C 先见边,然后dfs,在回溯的过程中,如果在这个点之后有多条有问题的边,就不选这个点,如果没有而且连接这个点的边还 ...

  7. wpf只运行一个实例

    原文:wpf只运行一个实例 在winform下,只运行一个实例只需这样就可以: 1. 首先要添加如下的namespace: using System.Threading; 2. 修改系统Main函数, ...

  8. Git本地版本控制备忘

    首先git是一个版本控制工具,类似于SVN 笔记包括两部分,git本地版本控制和git远程协助 一.Git本地版本控制 以git windows版本msysgit为例,下载地址http://msysg ...

  9. poj 2229 Ultra-QuickSort(树状数组求逆序数)

    题目链接:http://poj.org/problem?id=2299 题目大意:给定n个数,要求这些数构成的逆序对的个数. 可以采用归并排序,也可以使用树状数组 可以把数一个个插入到树状数组中, 每 ...

  10. [置顶] 顿悟JAVA,自己实现Object的Clone的约束关系(上)

    因protected 的理解,顿悟一些JAVA的原理,模拟了Object类的子类为什么在调用clone方法前实现Cloneable接口. 这里不解释 ,上代码先. 运行效果 文件结构 调用类 pack ...