zoukankan      html  css  js  c++  java
  • HTML5新特性 websocket(重点)--多对多聊天室

    一、html5新特性  websocket(重点)--多对多聊天室

       HTTP:超文本传输协议

       HTTP作用:传输网页中资源(html;css;js;image;video;..)

       HTTP是浏览器搬运工

       HTTP 工作方式:请示与响应

       浏览器发服务器信息(请求数据)

       服务器发数据给浏览器(响应消息)

       #一次请求对应一次响应,如果没有请求就没有响应

       

       #金融行业(股票/期货/汇率/...)  多长时间请求一次

     

       新解决方案方式:新协议 websocket

       websocket工作方式:广播和收听

      适用范围:金融;弹幕;聊天室;客服

     二、html5新特性  websocket(重点)--使用

       服务器端:node.js  scoket.io 最方便最简单

       客户端:浏览器原生对象 websocket功能较少  

              第三方:socket.io

       

       #socket.io 多对多聊天室

       

      #服务器端  下载第三方模块  (socket.io) 02_socketapp.js

       npm i socket.io

      #客户端    下载第三方模块  (socket.io) 02_socket.html

       https://cdnjs.cloudflare.com/ajax/libs/socket.io/2.0.3/socket.io.js

      

      

      #服务器端程序

      (1)创建web 服务器

        var app = require("http").createServer();

      (2)创建socketio 服务器端对象

        var io = require("socket.io")(app)

      (3)监听端口

        app.listen(3000);

      (4)为io对象绑定事件 connection (当客户连接服务器触发此事件)

        io.on("connection",(socket)=>{

         #console.log("有客户端连接服务器....");

         #socket 为当前客户创建专属服务员...

       })

      

      #客户端程序

      (1)创建socket对象并且连接服务器

       var clientSocket = io("ws://127.0.0.1:3000");

       #ws: websocket

       #127.0.0.1 服务器端程序所有机器地址

       #3000     服务器运行端口号

     

      #==========================================

      #客户端发送数据给服务器 (一对一)

      #socket.io 发送与接收数据采用方式事件绑定与事件触发机制

      服务器(收)

       socket.on("message",(data)=>{console.log(data);})

      客户端(发)

       clientSocket.emit("message","初始见面多关照");

      #emit:触发指定事件

      

      #==========================================

      #服务器发送数据给客户端(一对一)

      客户端(收)

      clientSocket.on("server",(data)=>{})

      服务器(发)

      socket.emit("server","发送消息");

     #==========================================

      #广播消息:服务器向所有客户发送消息

      客户端(收)

      clientSocket.on("list",(data)=>{})

      服务器(发)

      io.emit("list","明天开始大降价");

    #==========================================

      服务器端默认事件:disconnect

      #当客户端关闭浏览器默认触发事件(客户端离开了)

     

     三、html5新特性  websocket(重点)--多对多聊天室

        server/03_chart_app.js

        client/03_chart.html

      

      

     四、html5 新特性  webStroage 

      解决问题:在客户端浏览器中保存用户专用数据

      作用:登录用户昵称;购物车购物车;...

      #注意事项:webStorage 客户端不要存储安全级别高数据

      #安全级别高数据 用户密码;uid

      

    客户端存储方式

    服务器端存储方式

    (不安全;数据量很少)

    (安全/海量/高速查询)

    (1)cookie

    优点:兼容性好

    缺点:操作复杂;1kb

    (1)数据库

    (2)Flash

    缺点:依赖flash播放器

    (2)session 对象(数据量少)

    (3)WebStorage

    优点:操作简单;8MB

    缺点:兼容性

    (3)文件   data.txt

    (4)IndexDB 不标准

    (4)内存数据库,文档数据库

      

      WebStorage 存储数据依赖二个对象

      #sessionStorage

       sessionStorage对象存储范围在当前会话中.当前会话中所有网页

       都可以使用sessionStorage 保存,但是如果会话结束数据丢失!

       注意事项:会话结束(关闭浏览器-关闭标签),退出浏览器生效

      #localStorage

       此对象保存数据永久保存

      

      WebStorage 操作数据方法与属性以上两个对象通用

      (1)保存数据      setItem(key,value);  #key键  value 值

      (2)获取数据      var value = getItem(key);

      (3)删除指定数据  removeItem(key);

      (4)清空所有数据  clear()

      (5)数据长度      length

  • 相关阅读:
    64码高清网络电视V2.4.2
    无线网络探测V1.22
    居民身份证号码查询系统
    ORA-12505 TNS:listener does not currently know of SID given in connect descriptor
    weblogic项目部署问题--Deployment could not be created. Deployment creator is null.
    ORA-01461: can bind a LONG value only for insert into a LONG column 解决方法
    前端基础知识学习第五节(Vue篇)
    前端基础知识学习第三节
    前端基础知识学习第二节
    你真的会用parseInt方法吗?
  • 原文地址:https://www.cnblogs.com/sna-ling/p/12423501.html
Copyright © 2011-2022 走看看