socket笔记
参考:
http://www.cnblogs.com/dolphinX/p/3460545.html
http://www.cnblogs.com/wei2yi/archive/2011/03/23/1992830.html
http://www.2cto.com/net/201211/166537.html
概念:
TCP协议与HTTP协议区别:
HTTP协议是短链接,单向通信,属于OSI参考模型里的应用层协议
TCP协议是长链接,双工通信,属于OSI参考模型里的传输层协议
---------------------------------------------------------------------------------------------------------
socket:
socket是对TCP/IP协议的封装,它是在应用层和传输层之间的一个抽象层,它把TCP/IP层复杂的操作抽象为几个简单的接口供应用层调用以实现进程在网络中通信。通过Socket,我们才能使用TCP/IP协议,简而言之,socket是调用TCP/IP协议的API。
---------------------------------------------------------------------------------------------------------
WebSocket API是下一代客户端-服务器的异步通信方法,是W3C推动的一个客户端标准,隶属于HTML5的范畴。
用法如下:
WebSocket API是只专注于客户端的API,因为每个服务器端语言有自己的API。下面的代码片段是打开一个连接,为连接创建事件监听器,断开连接,消息时间,发送消息返回到服务器,关闭连接。
var socket = new WebSocket('ws://localhost:8080');
// 打开Socket
socket.onopen = function(event) {
// 发送一个初始化消息
socket.send('I am the client and I\'m listening!');
// 监听消息
socket.onmessage = function(event) {
console.log('Client received a message',event);
};
// 监听Socket的关闭
socket.onclose = function(event) {
console.log('Client notified socket has closed',event);
};
// 关闭Socket....
//socket.close()
};
---------------------------------------------------------------------------------------------------------
Socket.IO:
由于有的低版本浏览器不支持WebSocket,所以出现了一个Socket.IO技术,他是对WebSocket的封装,不仅实现了ws协议,也支持长轮询等方式,兼容flash,IE6等不支持ws协议的浏览器。
简单例子:
服务端:
var app = require('http').createServer(handler), //创建一个HTTP服务器
io = require('socket.io').listen(app),//把服务器实例传递给Socket.IO
fs = require('fs'),url = require("url"); app.listen(8080);//绑定8080端口 function handler (req, res) { fs.readFile(__dirname + '/home.html',function (err, data) {
if (err) {
res.writeHead(500);
return res.end('Error loading home.html');
}
res.writeHead(200, {'Content-Type': 'text/html'});
res.end(data);
}); } io.sockets.on('connection', function (socket) { //监听socket连接,执行回调
socket.emit('news',{'name':'zzn'});//发射一个news事件
socket.on('my other event', function (data) {//监听my other event这个事件
console.log(data);
});
});
客户端home.html:
<script src="//cdn.bootcss.com/socket.io/1.3.7/socket.io.js"></script>
<script type="text/javascript">
var socket = io.connect('http://localhost:8080/');//建立socket连接
socket.on('news', function (data) {//监听news事件
console.info(data)
socket.emit('my other event', { my: 'data' });//发射my other event这个事件
});
</script>
---------------------------------------------------------------------------------------------------------
socket.io API
http://www.cnblogs.com/xiezhengcai/p/3956401.html
socket笔记的更多相关文章
- iOS socket 笔记
ios 客服端: 下载 AsyncSocket 开发框架,拖到项目中 //建立 #import "ViewController.h" #import <sys/socket. ...
- linux c socket笔记 -服务端
#include <stdio.h> #include <stdlib.h> #include <string.h> #include <sys/types. ...
- C# Socket笔记
看到这个题目,是不是很眼熟?在博客园里搜下,保证会发现关于这个东东的文章实在是太多了~~~真得是没有写得必要,而且我也有点懒得去琢磨字句.(看到这,肯定得来个转折的了,不然就看不到下文了,不是吗)但是 ...
- socket 笔记(一)
#include "stdafx.h" #include "WINSOCK2.H" #pragma comment(lib,"WS2_32.lib&q ...
- 操作socket笔记
网络编程 1.tcp协议 #tcpserver #单纯一对一发 tcp = socket.socket(socket.AF_INET, socket.SOCK_STREAM) # 创建tcp套接字 参 ...
- TCP IP SOCKET 笔记
网络由下往上分为 物理层.数据链路层.网络层.传输层.会话层.表示层和应用层. 通过初步的了解,我知道IP协议对应于网络层,TCP协议对应于传输层,而HTTP协议对应于应用层, 三者从本质上来说没有可 ...
- tcp/ip http socket笔记
1.TCP/IP协议是传输层协议,主要解决数据如何在网络中传输 HTTP是应用层协议,主要解决如何包装数据 2.TCP连接的三次握手 第一次握手:客户端发送syn包到服务器,并进入SYN_SEND状态 ...
- C# Socket编程笔记(转)
C# Socket编程笔记 http://www.cnblogs.com/stg609/archive/2008/11/15/1333889.html TCP Socket:Server 端连接步骤: ...
- Android Socket编程学习笔记
http://blog.csdn.net/eyu8874521/article/details/8847173 度娘给出的描述:通常也称作"套接字",用于描述IP地址和端口,是一个 ...
随机推荐
- leetcode(144,94,145,102)中迭代版的二叉树的前、中、后、层级遍历
//前序遍历class Solution{ public: vector<int> preorderTraversal(TreeNode *root){ vector<int> ...
- Python::OS 模块 -- 简介
OS 模块简介 OS模块是Python标准库中的一个用于访问操作系统功能的模块,OS模块提供了一种可移植的方法使用操作系统的功能.使用OS模块中提供的接口,可以实现跨平台访问.但是在OS模块中的接口并 ...
- 数据库update死锁
比较常见的死锁场景,并发批量update时的一个场景: update cross_marketing set gmtModified = NOW(), pageview = pageview+ #ex ...
- remove adapter
Although adapter and other technical sequences can potentially occur in any location within reads, b ...
- JS 点击复制Copy (share)
分享自:http://www.cnblogs.com/athens/archive/2013/01/16/2862981.html 1.实现点击按钮,复制文本框中的的内容 1 <script t ...
- Java配置环境变量
首先,你应该已经安装了Java 的 JDK 了,笔者安装的是:jdk-7u7-windows-x64 接下来主要讲怎么配置 Java 的环境变量 1.进入“计算机”的“属性”选项后如图 2.选择“高级 ...
- 如何在JBoss WildFly 8 自定义log4j日志
最近在 JBoss WildFly 8 下部署 Web应用,自定义的 log4j 日志不工作.console下无日志输出,用System.out.println都不输出内容到console. 原因是J ...
- chrome 49 版本 跨越 --args --disable-web-security --user-data-dir
转载: 做前端的,用Ajax获取数据,是常有的事情,同域下自然没问题了,如果是不同域获取数据,浏览器就有个同源策略的限制. 如图: Origin * is not allowed by Access- ...
- NGINX + LUA实现复杂的控制 --源自http://outofmemory.cn/code-snippet/14396/nginx-and-lua
安装lua_nginx_module 模块 lua_nginx_module 可以一步步的安装,也可以直接用淘宝的OpenResty Centos和debian的安装就简单了.. 这里说下freebs ...
- CSS 类选择器
在 CSS 中,类选择器以一个点号显示: .center {text-align: center} 在上面的例子中,所有拥有 center 类的 HTML 元素均为居中. 在下面的 HTML 代码中, ...