CAsyncSocket类介绍

WinSock类

在Visual C++的MFC类库中,提供了两个与WinSock相关的类,分别为CAsyncSocket类和CSocket类。这两个类对WinSock API进行了封装,使得开发Windows Socket应用程序变得简单了。本节将针对CAsyncSocket介绍Windows Socket应用程序的开发。

CAsyncSocket类介绍

CAsyncSocket类对WinSock API进行了低级封装,它提供的许多方法直接对应于低层的API函数。在使用CAsyncSocket时,首先需要调用构造函数创建CAsyncSocket对象,然后调用Create方法创建套接字句柄,对于服务器端的套接字,需要调用Listen方法使其处于监听模式,对于客户端套接字,需要调用Connect方法连接服务器。下面介绍CAsyncSocket的主要方法和事件。

(1)Create方法

Create方法用于创建一个Windows 套接字。
语法:

BOOL Create( UINT nSocketPort = 0, 
int nSocketType = SOCK_STREAM, 
long lEvent = FD_READ | FD_WRITE | FD_OOB | FD_ACCEPT 
| FD_CONNECT | FD_CLOSE, LPCTSTR lpszSocketAddress = NULL ); 

Create方法参数说明:
参 数 名 称 参 数 描 述
nSocketPort 标识套接字端口
nSocketType 标识套接字类型,默认为流式套接字
lEvent 表示套接字能够接受的事件
lpszSocketAddress 表示套接字的网络地址

(2)GetLastError方法

GetLastError方法用于获得最后一次操作失败的状态信息。
语法:

static int GetLastError( );
(3)GetPeerName方法

GetPeerName方法用于获得套接字连接的IP地址。
语法:

BOOL GetPeerName( CString& rPeerAddress, UINT& rPeerPort );

BOOL GetPeerName( SOCKADDR* lpSockAddr, int* lpSockAddrLen ); 

GetPeerName方法参数说明:
参 数 名 称 参 数 描 述
rPeerAddress 用于接收函数返回的IP地址
rPeerPort 用于记录端口号
lpSockAddr 是一个sockaddr结构指针,用于记录套接字名称
lpSockAddrLen 用于确定lpSockAddr的大小

(4)Accept方法

Accept方法用于接受一个套接字的连接。
语法:

virtual BOOL Accept( CAsyncSocket& rConnectedSocket, 
SOCKADDR* lpSockAddr = NULL, int* lpSockAddrLen = NULL ); 

Accept方法参数说明:
rConnectedSocket:当前连接的套接字引用。
lpSockAddr:一个SOCKADDR结构指针,用于记录套接字地址。
lpSockAddrLen:确定lpSockAddr的大小。

(5)Bind方法

Bind方法将本机地址关联到套接字上。
语法:

BOOL Bind( UINT nSocketPort, LPCTSTR lpszSocketAddress = NULL );

BOOL Bind ( const SOCKADDR* lpSockAddr, int nSockAddrLen ); 

Bind方法参数说明:
参 数 名 称 参 数 描 述
nSocketPort 标识套接字端口
lpszSocketAddress 标识IP地址
lpSockAddr 是一个SOCKADDR结构指针,该结构记录了套接字的地址信息
nSockAddrLen 确定lpSockAddr的大小

(6)Close方法

Close方法用于关闭套接字。
语法:

virtual void Close( ); 

说明:
Close方法释放套接字描述符,因此,在调用该方法后,再对其进行访问,会导致错误。当CAsyncSocket对象被释放时,会自动调用Close方法。

(7)Connect方法

Connect方法用于建立一个套接字连接。
语法:

BOOL Connect( LPCTSTR lpszHostAddress, UINT nHostPort );

BOOL Connect( const SOCKADDR* lpSockAddr, int nSockAddrLen ); 

Connect方法参数说明:
参 数 名 称 参 数 描 述
lpszHostAddress 是主机的IP地址或网址
nHostPort 标识当前应用程序的端口
lpSockAddr 是一个SOCKADDR结构指针,该结构标识套接字地址信息
nSockAddrLen 确定lpSockAddr的大小

(8)Listen方法

Listen方法用于监听套接字的连接请求。
语法:

BOOL Listen( int nConnectionBacklog = 5 ); 

nConnectionBacklog:表示等待连接的最大队列长度。

(9)Receive方法

Receive方法用于从一个套接字上接收数据。
语法:

virtual int Receive( void* lpBuf, int nBufLen, int nFlags = 0 ); 

Receive方法参数说明:

lpBuf:是接收数据的缓冲区。
nBufLen:确定缓冲区的长度。
nFlags:确定函数的调用模式,可选值如下。
l MSG_PEEK用来查看传来的数据,在序列前端的数据会被复制一份到返回缓冲区中,但是这个数据不会从序列中移走。
l MSG_OOB用来处理Out-Of-Band数据。

(10)ReceiveFrom方法

ReceiveFrom方法用于接收面向无连接传递的数据(数据报)。
语法:

int ReceiveFrom( void* lpBuf, int nBufLen, 
CString& rSocketAddress, UINT& rSocketPort, int nFlags = 0 );

int ReceiveFrom( void* lpBuf, int nBufLen, 
SOCKADDR* lpSockAddr, int* lpSockAddrLen, int nFlags = 0 ); 

ReceiveFrom方法参数说明:
参 数 名 称 参 数 描 述
lpBuf 是接收数据的缓冲区
nBufLen 是缓冲区的大小
rSocketAddress 用于接收数据报的目的地(IP地址)
rSocketPort 用于记录端口号
lpSockAddr 是一个SOCKADDR结构指针,用于记录套接字地址信息
lpSockAddrLen 确定lpSockAddr的大小
nFlags 标识函数调用方式

(11)Send方法

Send方法用于发送数据到连接的套接字上。
语法:

virtual int Send( const void* lpBuf, int nBufLen, 
int nFlags = 0 ); 

Send方法参数说明:

lpBuf:标识要发送数据的缓冲区。
nBufLen:确定缓冲区的大小。
nFlags:标识函数调用方法。

(12)SendTo方法

SendTo方法既可以在面向连接的套接字上发送数据,也可以在面向无连接的套接字上发送数据。
语法:

int SendTo( const void* lpBuf, int nBufLen, UINT nHostPort, 
LPCTSTR lpszHostAddress = NULL, int nFlags = 0 );

int SendTo( const void* lpBuf, int nBufLen, 
const SOCKADDR* lpSockAddr, int nSockAddrLen, int nFlags = 0 ); 

SendTo方法参数说明:

参 数 名 称 参 数 描 述
lpBuf 标识要发送数据的缓冲区
nBufLen 确定缓冲区大小
nHostPort 确定主机端口号
lpszHostAddress 确定主机地址(可以是域名或IP地址)
lpSockAddr 是一个SOCKADDR结构指针,用于确定主机套接字地址信息
nSockAddrLen 确定lpSockAddr的大小
nFlags 标识函数调用方式

(13)ShutDown方法

ShutDown方法用于在套接字上断开数据的发送或接收。
语法:

BOOL ShutDown( int nHow = sends ); 

nHow:确定ShutDown函数的行为,0表示不允许接收,1表示不允许发送,2表示不允许接收和发送。

(14)OnAccept事件

OnAccept事件在套接字接受连接请求时触发。
语法:

virtual void OnAccept( int nErrorCode ); 

nErrorCode:标识错误代码。

(15)OnClose事件

OnClose事件在连接的套接字被关闭时触发。
语法:

virtual void OnClose( int nErrorCode ); 

nErrorCode:标识错误代码。

(16)OnConnect事件

OnConnect事件在套接字被连接后触发。
语法:

virtual void OnConnect( int nErrorCode ); 

nErrorCode:标识错误代码。

(17)OnOutOfBandData事件

OnOutOfBandData事件在接收数据的套接字收到Out-Of-Band数据时触发。
语法:

virtual void OnOutOfBandData( int nErrorCode ); 

nErrorCode:标识错误代码。

(18)OnReceive事件

OnReceive事件在套接字有数据被接收时触发。
语法:

virtual void OnReceive( int nErrorCode ); 

nErrorCode:标识错误代码。

(19)OnSend事件

OnSend事件在套接字发送数据时触发。
语法:

virtual void OnSend( int nErrorCode ); 

nErrorCode:标识错误代码。

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值