淺談C++ Socket編程
sockets(套接字)編程有三種,流式套接字(SOCK_STREAM),數(shù)據(jù)報(bào)套接字(SOCK_DGRAM),原始套接字(SOCK_RAW);基于TCP的socket編程是采用的流式套接字。
服務(wù)器端編程的步驟:
1:加載套接字庫,創(chuàng)建套接字(WSAStartup()/socket());
2:綁定套接字到一個(gè)IP地址和一個(gè)端口上(bind());
3:將套接字設(shè)置為監(jiān)聽模式等待連接請(qǐng)求(listen());
4:請(qǐng)求到來后,接受連接請(qǐng)求,返回一個(gè)新的對(duì)應(yīng)于此次連接的套接字(accept());
5:用返回的套接字和客戶端進(jìn)行通信(send()/recv());
6:返回,等待另一連接請(qǐng)求;
7:關(guān)閉套接字,關(guān)閉加載的套接字庫(closesocket()/WSACleanup())。
客戶端編程的步驟:
1:加載套接字庫,創(chuàng)建套接字(WSAStartup()/socket());
2:向服務(wù)器發(fā)出連接請(qǐng)求(connect());
3:和服務(wù)器端進(jìn)行通信(send()/recv());
4:關(guān)閉套接字,關(guān)閉加載的套接字庫(closesocket()/WSACleanup())。
第一式: 加載/釋放Winsock庫:
1.加載方法:
WSADATA wsa; /*初始化socket資源*/ if (WSAStartup(MAKEWORD(1,1),&wsa) != 0) { return; //代表失敗 }
2.釋放方法:
WSACleanup();
第二式: 構(gòu)造SOCKET:
1.服務(wù)端:構(gòu)造監(jiān)聽SOCKET,流式SOCKET.
SOCKET Listen_Sock = socket(AF_INET, SOCK_STREAM, 0)
2.客戶端:構(gòu)造通訊SOCKET,流式SOCKET.
SOCKET Client _Sock = socket(AF_INET, SOCK_STREAM, 0)
第三式:配置監(jiān)聽地址和端口:
1.服務(wù)端: SOCKADDR_IN
serverAddr ZeroMemory((char *)& serverAddr ,sizeof( serverAddr )); serverAddr .sin_family = AF_INET ; serverAddr .sin_port = htons( 1234 ); /*本地監(jiān)聽端口:1234*/ serverAddr .sin_addr.s_addr = htonl( INADDR_ANY ); /*有IP*/
第四式: 綁定SOCKET:
1.服務(wù)端:綁定監(jiān)聽SOCKET.
bind( Listen_Sock, (struct sockaddr *)& serverAddr, sizeof( serverAddr ))
第五式: 服務(wù)端/客戶端連接:
1.服務(wù)端:等待客戶端接入.
SOCKET Command_Sock = accept( Listen_Sock , ...)
2.客戶端:請(qǐng)求與服務(wù)端連接.
int ret = connect( Client_Sock , ...)
第六式: 收/發(fā)數(shù)據(jù):
1.服務(wù)端:等待客戶端接入.char buf[1024].
接收數(shù)據(jù):recv( Command_Sock ,buf, ...)
或
發(fā)送數(shù)據(jù):send( Command_Sock ,buf, ...)
2.客戶端:請(qǐng)求與服務(wù)端連接.char buf[1024].
發(fā)送數(shù)據(jù):send( Client _Sock ,buf, ...)
或
接收數(shù)據(jù):recv( Client _Sock ,buf, ...)
第七式: 關(guān)閉SOCKET:
1.服務(wù)端:關(guān)閉SOCKET.
closesocket( Listen_Sock )
closesocket( Command_Sock )
2.客戶端:關(guān)閉SOCKET.
closesocket( Client_Sock ) #include <stdio.h> #include <Winsock2.h> void main() { WORD wVersionRequested; WSADATA wsaData; int err; wVersionRequested = MAKEWORD( 1, 1 ); err = WSAStartup( wVersionRequested, &wsaData ); if ( err != 0 ) { return; } if ( LOBYTE( wsaData.wVersion ) != 1 || HIBYTE( wsaData.wVersion ) != 1 ) { WSACleanup( ); return; } SOCKET sockClient=socket(AF_INET,SOCK_STREAM,0); SOCKADDR_IN addrSrv; addrSrv.sin_addr.S_un.S_addr=inet_addr("127.0.0.1"); addrSrv.sin_family=AF_INET; addrSrv.sin_port=htons(6000); connect(sockClient,(SOCKADDR*)&addrSrv,sizeof(SOCKADDR)); send(sockClient,"hello",strlen("hello")+1,0); char recvBuf[50]; recv(sockClient,recvBuf,50,0); printf("%s\n",recvBuf); closesocket(sockClient); WSACleanup(); }
相關(guān)文章
Visual Studio新建類從默認(rèn)internal改為public
本文將介紹如何將Visual Studio中的internal修飾符更改為public,以實(shí)現(xiàn)更廣泛的訪問和重用,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2023-09-09算法學(xué)習(xí)入門之使用C語言實(shí)現(xiàn)各大基本的排序算法
這篇文章主要介紹了使用C語言實(shí)現(xiàn)各大基本的排序算法的方法,同時(shí)也對(duì)算法的選擇問題上給出了一些建議,的朋友可以參考下2015-12-12帶你用C語言實(shí)現(xiàn)strtok和字符串分割函數(shù)
下面小編就為大家?guī)硪黄猚語言中字符串分割函數(shù)及實(shí)現(xiàn)方法。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2021-09-09C語言簡(jiǎn)明分析選擇結(jié)構(gòu)和循環(huán)結(jié)構(gòu)的使用
C語言條件控制語句選擇結(jié)構(gòu),是屬于計(jì)算機(jī)的語言編輯,有在C語言條件控制中的語句選擇結(jié)構(gòu)的存在,即是C語言條件控制語句選擇結(jié)構(gòu),循環(huán)控制語句是一個(gè)基于C語言的編程語句,該語句主要有while循環(huán)語句、do-while循環(huán)語句和for循環(huán)語句來實(shí)現(xiàn)循環(huán)結(jié)構(gòu)2022-04-04C++實(shí)現(xiàn)LeetCode(30.串聯(lián)所有單詞的子串)
這篇文章主要介紹了C++實(shí)現(xiàn)LeetCode(30.串聯(lián)所有單詞的子串),本篇文章通過簡(jiǎn)要的案例,講解了該項(xiàng)技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下2021-07-07C++ Dijkstra算法之求圖中任意兩頂點(diǎn)的最短路徑
這篇文章主要為大家詳細(xì)介紹了用C++經(jīng)典算法-Dijkstra算法求任意兩頂點(diǎn)之間的最短路徑,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-11-11