一、socket是什么

 Socket是应用层与TCP/IP协议族通信的中间软件抽象层,它是一组接口。在设计模式中,Socket其实就是一个门面模式,它把复杂的TCP/IP协议族隐藏在Socket接口后面,对用户来说,一组简单的接口就是全部,让Socket去组织数据,以符合指定的协议。所以,我们无需深入理解tcp/udp协议,socket已经为我们封装好了,我们只需要遵循socket的规定去编程,写出的程序自然就是遵循tcp/udp标准的。

二、套接字的工作流程

先从服务器端说起。服务器端先初始化Socket,然后与端口绑定(bind),对端口进行监听(listen),调用accept阻塞,等待客户端连接。在这时如果有个客户端初始化一个Socket,然后连接服务器(connect),如果连接成功,这时客户端与服务器端的连接就建立了。客户端发送数据请求,服务器端接收请求并处理请求,然后把回应数据发送给客户端,客户端读取数据,最后关闭连接,一次交互结束。

三、服务端

private void btnListen_Click(object sender, EventArgs e)
{
IPEndPoint point = new IPEndPoint(IPAddress.Any, 13000);//IPAddress.Any本机任何网卡IP。本机端口查看netstat -an
//服务端Socket定义
Socket socket = new Socket(AddressFamily.InterNetwork, SocketType.Stream, ProtocolType.Tcp);
socket.Bind(point); //绑定IP
socket.Listen();//启动监听。最大监听数,同一个时间点过来10个客户端,排队
ShowMsg("服务器开始监听"); Thread thread = new Thread(AcceptInfo);
thread.Start(socket); } //记录通信用的Socket
Dictionary<string, Socket> dic = new Dictionary<string, Socket>(); // private Socket client;
void AcceptInfo(object o)
{
Socket socket = o as Socket;
while (true)
{
//通信用socket
try
{
Socket clientSocket = socket.Accept();//如果客户端有请求,生成一个新的Socket
string point = clientSocket.RemoteEndPoint.ToString();
ShowMsg(point + "连接客户端成功!");
dic.Add(point, clientSocket);
//接收消息
Thread th = new Thread(ReceiveMsg);
th.Start(clientSocket);
}
catch (Exception ex)
{
break;
}
}
socket.Close();
}
//接收消息
void ReceiveMsg(object socket)
{
Socket clientSocket = socket as Socket;
while (true)
{
//接收客户端发送过来的数据
try
{
//定义byte数组存放从客户端接收过来的数据
byte[] buffer = new byte[ * ];
           int n = clientSocket.Receive(buffer);//将接收过来的数据放到buffer中,并返回实际接受数据的长度

            //将字节转换成字符串
string words = Encoding.Unicode.GetString(buffer, , n);
Console.WriteLine(clientSocket.RemoteEndPoint.ToString() + ":" + words);
byte[] msg = Encoding.Unicode.GetBytes(words);
clientSocket.Send(msg);//发送数据,字节数组
}
catch (Exception ex)
{
break;
}
}
clientSocket.Shutdown(SocketShutdown.Both);//禁止发送和接受数据
clientSocket.Close();//关闭socket,释放资源
}

四、客户端

Socket clientSocket = new Socket(AddressFamily.InterNetwork, SocketType.Stream, ProtocolType.Tcp);
IPEndPoint point = new IPEndPoint("127.0.0.1", ));//连接到的服务端IP
clientSocket.Connect(point);//连接到服务器
ShowMsg("连接成功");
ShowMsg("服务器" + client.RemoteEndPoint.ToString());
ShowMsg("客户端:" + client.LocalEndPoint.ToString());
Thread th = new Thread(ReceiveMsg);//连接成功后,就可以接收服务器发送的信息了
th.IsBackground = true;
th.Start(); clientSocket.Shutdown(SocketShutdown.Both);//禁止发送和接受数据
clientSocket.Close();//关闭socket,释放资源

五、Socket对象的成员

属性

AddressFamily    获取 Socket 的地址族。
Available 获取已经从网络接收且可供读取的数据量。
Blocking 获取或设置一个值,该值指示 Socket 是否处于阻止模式。
Connected 获取一个值,该值指示 Socket 是在上次 Send 还是 Receive 操作时连接到远程主机。
Handle 获取 Socket 的操作系统句柄。
LocalEndPoint 获取本地终结点。
RemoteEndPoint 获取远程终结点。
ProtocolType 获取 Socket 的协议类型。
SocketType 获取 Socket 的类型。
ReceiveBufferSize 获取或设置一个值,它指定 Socket 接收缓冲区的大小。
ReceiveTimeout 获取或设置一个值,该值指定之后同步 Receive 调用将超时的时间长度。
SendBufferSize 获取或设置一个值,该值指定 Socket 发送缓冲区的大小。
SendTimeout 获取或设置一个值,该值指定之后同步 Send 调用将超时的时间长度。

方法

//Accept(----------------
Accept() 为新建连接创建新的 Socket。
BeginAccept(AsyncCallback, Object) 开始一个异步操作来接受一个传入的连接尝试。
EndAccept(Byte[], IAsyncResult) 异步接受传入的连接尝试,并创建新的 Socket 对象来处理远程主机通信。 此方法返回包含所传输的初始数据的缓冲区。
AcceptAsync(SocketAsyncEventArgs) 开始一个异步操作来接受一个传入的连接尝试。 //Connect----------------
Connect(EndPoint) 与远程主机建立连接。
BeginConnect(EndPoint, AsyncCallback, Object) 开始一个对远程主机连接的异步请求。
EndConnect(IAsyncResult) 结束挂起的异步连接请求。
ConnectAsync(SocketAsyncEventArgs) 开始一个对远程主机连接的异步请求。 //Disconnect----------------
Disconnect(Boolean) 关闭套接字连接并允许重用套接字。
BeginDisconnect(Boolean, AsyncCallback, Object) 开始异步请求从远程终结点断开连接。
EndDisconnect(IAsyncResult) 结束挂起的异步断开连接请求。
DisconnectAsync(SocketAsyncEventArgs) 关闭套接字连接并允许重用套接字。 //Receive----------------
Receive(Byte[]) 从绑定的 Socket 套接字接收数据,将数据存入接收缓冲区。
BeginReceive(Byte[], Int32, Int32, SocketFlags, AsyncCallback, Object) 开始从连接的 Socket 中异步接收数据。
EndReceive(IAsyncResult) 结束挂起的异步读取。
ReceiveAsync(SocketAsyncEventArgs) 开始一个异步请求以便从连接的 Socket 对象中接收数据。 //ReceiveFrom----------------
ReceiveFrom(Byte[], EndPoint) 将数据报接收到数据缓冲区并存储终结点。
BeginReceiveFrom(Byte[], Int32, Int32, SocketFlags, EndPoint, AsyncCallback, Object) 开始从指定网络设备中异步接收数据。
EndReceiveFrom(IAsyncResult, EndPoint) 结束挂起的、从特定终结点进行异步读取。
ReceiveFromAsync(SocketAsyncEventArgs) 开始从指定网络设备中异步接收数据。 //ReceiveMessageFrom----------------
ReceiveMessageFrom(Byte[], Int32, Int32, SocketFlags, EndPoint, IPPacketInformation) 使用指定的 SocketFlags 将指定字节数的数据接收到指定的数据缓冲区位置,并存储终结点和数据包信息。
BeginReceiveMessageFrom(Byte[], Int32, Int32, SocketFlags, EndPoint, AsyncCallback, Object) 开始使用指定的 SocketFlags 将指定字节数的数据异步接收到数据缓冲区的指定位置,然后存储终结点和数据包信息。
EndReceiveMessageFrom(IAsyncResult, SocketFlags, EndPoint, IPPacketInformation) 结束挂起的、从特定终结点进行异步读取。 此方法还显示有关数据包而不是 EndReceiveFrom(IAsyncResult, EndPoint) 的更多信息。
ReceiveMessageFromAsync(SocketAsyncEventArgs) 开始使用指定的 SocketFlags 将指定字节数的数据异步接收到数据缓冲区的指定位置,并存储终结点和数据包信息。 //Send----------------
Send(Byte[]) 将数据发送到连接的 Socket。
BeginSend(Byte[], Int32, Int32, SocketFlags, AsyncCallback, Object) 将数据异步发送到连接的 Socket。
EndSend(IAsyncResult) 结束挂起的异步发送。
SendAsync(SocketAsyncEventArgs) 将数据异步发送到连接的 Socket 对象。 //SendFile----------------
SendFile(String) 使用 Socket 传输标志,将文件 fileName 发送到连接的 UseDefaultWorkerThread 对象。
BeginSendFile(String, AsyncCallback, Object) 使用 Socket 标志,将文件 fileName 发送到连接的 UseDefaultWorkerThread 对象。
EndSendFile(IAsyncResult) 结束文件的挂起异步发送。 //SendTo----------------
SendTo(Byte[], EndPoint) 将数据发送到指定的终结点。
BeginSendTo(Byte[], Int32, Int32, SocketFlags, EndPoint, AsyncCallback, Object) 以异步方式将数据发送到特定远程主机。
EndSendTo(IAsyncResult) 结束挂起的、向指定位置进行的异步发送。
SendToAsync(SocketAsyncEventArgs) 以异步方式将数据发送到特定远程主机。 //-------------
Select(IList, IList, IList, Int32) 确定一个或多个套接字的状态。
SendPacketsAsync(SocketAsyncEventArgs) 将文件集合或者内存中的数据缓冲区以异步方法发送给连接的 Socket 对象。
Bind(EndPoint) 使 Socket 与一个本地终结点相关联。
Listen(Int32) 将 Socket 置于侦听状态。
CancelConnectAsync(SocketAsyncEventArgs) 取消一个对远程主机连接的异步请求。
GetSocketOption(SocketOptionLevel, SocketOptionName) 返回指定的 Socket 选项的值,表示为一个对象。
SetSocketOption(SocketOptionLevel, SocketOptionName, Boolean) 将指定的 Socket 选项设置为指定的 Boolean 值。
SetIPProtectionLevel(IPProtectionLevel) 设置套接字的 IP 保护级别。
Shutdown(SocketShutdown) 禁用某 Socket 上的发送和接收。
Close() 关闭 Socket 连接并释放所有关联的资源。
Dispose() 释放 Socket 类的当前实例所使用的所有资源。

Socket嵌套字通讯的更多相关文章

  1. day37协程与线程套接字通讯

    协程与线程套接字通讯基于多线程实现套接字服务端支持并发,服务端 from socket import * from threading import Thread def comunicate(con ...

  2. C# Socket的TCP通讯

    Socket的TCP通讯 一. socket的通讯原理 服务器端的步骤如下. (1)建立服务器端的Socket,开始侦听整个网络中的连接请求. (2)当检测到来自客户端的连接请求时,向客户端发送收到连 ...

  3. Android 通过Socket 和服务器通讯

    Extends:(http://www.cnblogs.com/likwo/p/3641135.html) Android 通过Socket 和服务器通讯,是一种比较常用的通讯方式,时间比较紧,说下大 ...

  4. 零配置Socket TCP消息通讯服务容器EC

    EC全称是elastic communication,是基于c#实现的Socket网络通讯服务容器,支持windows .Net和mono.通过EC容器可以让开发人员在不了解Socket网络通讯知识和 ...

  5. python socket 模拟tcp通讯

    对于tcp server 端的创建而言, 分为如下步骤:   1,创建socket对象(socket):其中俩个参数分别为     Address Family(如AF_INET为ipv4),AF_I ...

  6. [C#]手把手教你打造Socket的TCP通讯连接(一)

    本文章将讲解基于TCP连接的Socket通讯,使用Socket异步功能,并且无粘包现象,通过事件驱动使用. 在编写Socket代码之前,我们得要定义一下Socket的基本功能. 作为一个TCP连接,不 ...

  7. socket UDP简单通讯

    // // SocketUDPServerClient.m // socket_server_client // // Created by lujunjie on 2016/11/26. // Co ...

  8. socket TCP简单通讯

    socket 服务器 // // main.m // socket_server // // Created by lujunjie on 2016/11/23. // Copyright © 201 ...

  9. C# Socket的TCP通讯 异步 (2015-11-07 10:07:19)转载▼

    异步 相对于同步,异步中的连接,接收和发送数据的方法都不一样,都有一个回调函数,就是即使不能连接或者接收不到数据,程序还是会一直执行下去,如果连接上了或者接到数据,程序会回到这个回调函数的地方重新往下 ...

随机推荐

  1. Memcached的安装与常用命令

    一.概述 MSM:Memcached-Session-ManagerMemcached是一款高性能.分布式的内存对象缓存系统 二.安装Memcached 在安装Memcached之前,我们需要先安装上 ...

  2. K8S从入门到放弃系列-(7)kubernetes集群之kube-scheduler部署

    摘要: 1.Kube-scheduler作为组件运行在master节点,主要任务是把从kube-apiserver中获取的未被调度的pod通过一系列调度算法找到最适合的node,最终通过向kube-a ...

  3. Word 查找替换高级玩法系列之 -- 把论文中的缩写词快速变成目录下边的注释表

    1. 前言 问题:Word写论文如何把文中的缩写快速转换成注释表? 原来样子: 想要的样子: 2. 步骤 使用查找替换高级用法,替换缩写顺序 选中所有文字 打开查找替换对话框,输入以下表达式: 替换后 ...

  4. Qt程序开机自动运行

    一.写入注册表需要管理员权限 1.开发中生成并运行程序需要写入注册表时,应该以管理员权限打开项目: 2.点击程序运行需要写入注册表,则应该以管理员权限打开此程序. 二.实现 void MoreSetW ...

  5. 小程序文案过长,‘收起/展开’文字,createSelectorQuery 获取节点成功,boundingClientRect 返回信息null

    问题描述: wxml中id是动态生成的. 获取节点信息是在onReady生命周期函数内延时500ms执行的,select(id)可以获取全部节点信息,boundingClientRect (rect) ...

  6. WebSocket协议探究(二)

    一 复习和目标 1 复习 协议概述: WebSocket内置消息定界并且全双工通信 WebSocket使用HTTP进行协议协商,协商成功使用TCP连接进行传输数据 WebScoket数据格式支持二进制 ...

  7. tiny-Spring【2】逐步step分析-新加入特性

    tiny-Spring是黄亿华大佬自己写的一个集合IOC和AOP于一身的一种轻量级[教学用]Spring框架,它的github库地址为:https://github.com/code4craft/ti ...

  8. .net core partial view的一些心得

    原文:.net core partial view的一些心得 版权声明:本文为博主原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明. 本文链接:https://blog. ...

  9. Java Web 深入分析(4) Java IO 深入分析

    I/O问题可以说是现在海量数据时代下 ,I/O大部分web系统的瓶颈.我们要了解的java I/O(后面简称为(IO)) IO类库的基本结构 磁盘IO的工作机制 网络IO的工作机制 NIO的工作方式 ...

  10. Go微服务 grpc/protobuf

    了解grpc/protobuf gRPC是一个高性能.通用的开源RPC框架,其由Google主要面向移动应用开发并基于HTTP/2协议标准而设计,基于ProtoBuf(Protocol Buffers ...