MFC中网络编程,利用套接字的过程。

MFC中网络编程,利用套接字的过程。,第1张

1>调用WSAStartup()函数初始化套接字库;

2>调用socket()来创建郑腊套灶丛念接字句柄;

3>服务器的话,先用bind()绑定地址信息,在调用liesten()监听设置好的端口,如果请求到来,调用accept()响应请求。如果是客户端,则直接调用connect()连接服务器即可

4>调用send()和recv()等功能函数进行数据交换隐困传输处理

5>调用closesocket()关闭套接字,WSACleanup()关闭套接字库

一、接收与发送过程:

服务器端

1、创建服务器套接字(CREATE)。

2、服务器套接字进行信息绑定(BIND),并开始监听连接(LISTEN)。

3、接受来自客户端的连接请求(ACCEPT),并创建接收进程。

4、开始数据传输(SEND、RECEIVE)。

5、关闭套接字(CLOSESOCKET)。

客户机端

1、创建客户机套接字(CREATE)。

2、与远程服务器进行连接(CONNECT),如被接受则创建接收进程。

3、开始数据传输(SEND、RECEIVE)。

4、关闭套接字(CLOSESOCKET)。

二、在VC中的实现:

服务器端:

一、建立支持SOCKET项目。

利用APP WIZARD创建MFC EXE项目,进行到WIZARD的第四步时,在“What features would you like include?”中,选中“Windows Sockets”项。其它各步骤各选项根据实际应用进行选择即可。这样创建的项目就已经支持SOCKET,并已经初始化了。

如果要在已有的项目中添加SOCKET支持,只须进行两项工作:

1、在stdafx.h文件中包含头文件WINSOCK.H (#include “winsock.h” )。

2、在应用程败迹序类的成员函数:“::InitInstance()”中添加如下初始化套接字代码。

if (!AfxSocketInit())

{AfxMessageBox(IDP_SOCKETS_INIT_FAILED)return FALSE}

二、创建服务套接字并创建监听线程

//创建服务套接字

SOCKET sercon=socket(PF_INET,SOCK_STREAM,0)

//判断是否成功创建

if (sercon==INVALID_SOCKET)

{AfxMessageBox(“Server WRONG !”)return -1}

//配置套接字地址等信息

SOCKADDR_IN sin

sin.sin_family=AF_INET

//指定本地地址

sin.sin_addr.s_addr=htonl(INADDR_ANY)

//指定服务器端口号nPort,可自设

int 清棚nPort=5080

sin.sin_port=htons(nPort)

//地址信息与套接字进行绑定。

if (bind(sercon,(LPSOCKADDR)&sin,sizeof(sin))==SOCKET_ERROR)

{AfxMessageBox(“bind wrong!”)return -1}

//建立监听队列(大小为3),开始监听

if (listen(sercon,3)==SOCKET_ERROR)

{AfxMessageBox(“listen wrong!”)return -1}

①实现监听线程,并创建数据接收线程。

//在程序需要开始监听连接的地方答枯则创建监听线程,并实现。

//创建监听线程(在程序开始或按钮事件实现中)

AfxBeginThread(waitconnect,NULL);

//实现监听线程

UINT waitconnect(LPVOID lpParm)

{SOCKET conn[3]int lenc=sizeof(sockaddr)int alreadycon=0//sercon为前面所创建服务器套接字while(1){if (alreadycon<=3) {//接受连接请求conn[alreadycon]=accept(sercon,&cin,&lenc)if (conn[alreadycon]==INVALID_SOCKET){AfxMessageBox(“accept WRONG !”)}

else

{//创建数据接收线程

AfxBeginThread(readdata,&connn[alreadycon])

Alreadycon= alreadycon+1

return 0;}}

else

{//避免影响主线程运行

Sleep(200)}

}

}

②实现数据接收线程。

UINT waitconnect(LPVOID ss)

{ SOCKET *readsock

readsock=(SOCKET *)ss

char buf[2000]

int revnum=0

//开始循环接受数据

while (revnum!=-1)

{//revnum<=0则表示连接已断!

revnum=recv(*readsock,buf,2000,0)

if (revnum>0)

buf[revnum]=0//截断缓冲区

//buf中存储已接受数据。}

}

③发送数据

//conn[1]为用于接受连接的套接字, sendstr为所发送数据。

send(conn[1],LPCTSTR(sendstr),sendstr.GetLength(),0)

④关闭套接字。

//conn[1]为用于接受连接的套接字

closesocket(conn[1])

客户程序端:

客户端程序的编程有很多与服务器端相同或相近,甚至相同的代码。

一、建立支持SOCKET项目。

方法同服务器端。

二、创建客户套接字、对服务器进行连接。

//nHost 须用户指定的远程服务机,IP或域名。

CString nHost

//h为地址信息

struct hostent *h

h=gethostbyname(nHost)

//nHost 须用户指定的远程服务端口号

int nPort

SOCKET con_client

SOCKADDR_IN csin

if (h!=NULL)

{//创建套接字

con_client =socket(AF_INET,SOCK_STREAM,0)

csin.sin_family=AF_INET

memcpy(&(csin.sin_addr.s_addr),h->h_addr,sizeof(int))

csin.sin_port=htons(nPort)

//开始连接

if (connect(con_client,(LPSOCKADDR)&csin,sizeof(csin)))

{//AfxMessageBox(“connect wrong!”)

return -1}

else

{//连接成功,创建数据接收线程

AfxBeginThread(readdata,&con_client)}

}

三、实现数据接收线程。

代码与服务器端完全相同。

四、发送数据。

//con_client 为与服务器进行连接的套接字。

send(con_client,LPCTSTR(sendstr),sendstr.GetLength(),0)

五、关闭套接字。

// con_client 为与服务器进行连接的套接字。

closesocket(conn[1])

在实际应用中,应当根据需要调整并改变一些变量的作用域。


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/yw/8273251.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-04-14
下一篇 2023-04-14

发表评论

登录后才能评论

评论列表(0条)

保存