http,https,websocket

http

什么是http
  Hyper Text Transfer Protocol 超文本传输协议
  建立在TCP上无状态的连接
  客户端发送一个HTTP请求到服务器,服务器接收后开始处理请求并根据
  请求访问服务器资源,最后通过HTTP响应把结果返回给客户端

http请求
  状态行  请求方式Method(get/post/put/delete)、资源路径URL、
       协议版本Version
  请求头  访问的域名、用户代理、Cookie等信息
  请求正文 HTTP请求的数据

http响应
  状态行  协议版本Version、状态码Status Code、回应短语
  响应头  搭建服务器的软件,发送响应的时间,回应数据的格式等信息
  响应正文 响应的具体数据
       状态码
        1xx 请求已接收继续处理请求
        2xx 请求已经处理完成(200--请求正常处理完成)
        3xx 请求访问的URL重定向到其他目录
          301--请求永久重定向;
          302--请求临时重定向;
          304--请求被重定向到客户端本地缓存
        4xx 客户端出现错误
          400--客户端请求存在语法错误;
          401--请求没经过授权;
          403--请求被服务器端拒绝,客户端无访问权限;
          404--URL在服务端不存在
        5xx 服务端出现错误
          500--服务端永久错误;503--服务端发生临时错误
  响应模式
    单进程I/O模型   一进程仅处理一个请求,对请求顺序处理
    多进程I/O模型   多进程,同事处理多个请求
    复用I/O模型    一个进程多个线程,一个线程响应一个请求,
             可以达到同时处理多个请求,线程并发执行
    复用多线程I/O模型 多个进程多个线程

https

什么是https
  http的安全版,http下加入SSL层,https安全基础是SSL,加密的详细内容需要SSL

主要作用
  1.建立一个信息安全通道,保证数据传输的安全
  2.确认网站的真实性

原理、步骤
  客户端使用https的url访问web服务器,要求与服务器建立SSL连接
  服务器收到客户端请求后,会将网站的证书信息(证书包含公钥)传送一份给客户端
  客户端的浏览器和服务器开始协商SSL连接的安全等级,即信息加密等级
  客户端的里浏览器根据双方同意的安全等级建立会话秘钥,利用网站公钥将会话秘钥加密并传送给网站
  web服务器利用自己的私钥解密出会话的秘钥
  服务器利用会话秘钥加密与客户端之间的通信

优点
  可认证用户和服务器,确保数据 发送到正确 的客户机和服务器
  防止数据在传输过程中不被窃取改变 保证数据的完整性
  虽不是绝对安全的,但大幅度 增加了中间人的成本
  比起同等http网站,采用https加密的网站在 搜索 结果中 排名会更高

缺点
  握手阶段较 费时,使页面加载时间延长50%,增加10%到20%的耗电
  https连接缓存 如http 高效,增加数据开销和功耗,已有的安全措施也会因此受到影响
  SSL证书 需要钱,功能越强证书费用越高,个人网站小网站没必要一般不会用
  SSL证书 需要绑定IP,不能在同一IP上绑定多个域名,IPv4资源不可能支撑这个消耗
  加密范围有限,在黑客攻击、拒绝服务攻击、服务器劫持等方面几乎起不到什么作用

websocket

什么是websocket
  是一种网络通信协议,与http没有关系,是http的一种补充
  HTML5开始提供的一种在单个TCP连接上进行全双工通讯的协议

为什么用Websocket
  http协议是一种无状态、无连接、单向的应用层协议
  请求/响应模型。只能由客户端发起请求,服务端对请求做出应答处理
  HTTP协议无法实现服务器主动向客户端发起信息
  websocket允许客户端和服务器之间进行全双工通信,任何一方都可以通过建立的连接将数据推送到另一端。
  只需要建立一次连接就可以一直保持连接状态,比轮询方式效率高

客户端使用
  var Socket = new WebSocket(url,[protocol]);

属性
  Socket.readyState
    连接状态
      0:尚未建立;
      1:建立,可以进行通信;
      2:连接正在关闭;
      3:连接已经关闭或者连接不能打开
  Socket.bufferedAmount
    已被send()放入正在队列中等待传输,但是还没有发出的UTF-8文本字节数

事件
  Socket.onopen  连接建立时触发
  Socket.onmessage 客户端接收服务端数据时触发
  Socket.onerror  通信发生错误时触发
  Socket.onclose  连接关闭时触发

方法
  Socket.send()  使用连接发送数据
  Socket.close()  关闭连接

var ws = new WebSocket("ws://localhost:9998/echo");
ws.onopen = function () {                            // 使用 send() 方法发送数据  
  ws.send("发送数据");
  alert("数据发送中...");
};
ws.onmessage = function (evt) {                     // 接收服务端数据时触发事件
  var received_msg = evt.data;
  alert("数据已接收...");
};
ws.onclose = function () {                            // 断开 web socket 连接成功触发事件
  alert("连接已关闭...");
};

你可能感兴趣的:(http,https,websocket)