C++實現(xiàn)簡易UDP網絡聊天室
更新時間:2021年07月05日 08:37:41 作者:@[toc](目錄)
這篇文章主要為大家詳細介紹了C++實現(xiàn)簡易UDP網絡聊天室,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
本文實例為大家分享了C++實現(xiàn)簡易UDP網絡聊天室的具體代碼,供大家參考,具體內容如下
工程名:NetSrv
NetSrv.cpp
//服務器端
#include<Winsock2.h>
#include<stdio.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;
}
//創(chuàng)建套接字
SOCKET sockSrv = socket(AF_INET,SOCK_DGRAM,0);//第二個參數(shù)是數(shù)據(jù)報套接字
SOCKADDR_IN addrSrv;//對于服務器端,也就是接收端,先進行一個綁定,定義一個地址結構體的變量
addrSrv.sin_addr.S_un.S_addr=htonl(INADDR_ANY);//對結構體中的成員進行賦值,用htonl轉換一下
//將主機數(shù)轉換成無符號長整型的網絡字節(jié)順序。本函數(shù)將一個32位數(shù)從主機字節(jié)順序轉換成網絡字節(jié)順序。
addrSrv.sin_family=AF_INET;//地址族
addrSrv.sin_port=htons(6000);//端口號
//綁定套接字
bind(sockSrv,(SOCKADDR*)&addrSrv,sizeof(SOCKADDR));//將本地主機地址和端口進行綁定
//套接字,地址結構的指針,地址結構的長度
char recvBuf[100];//字符數(shù)組,接收信息
char sendBuf[100];//發(fā)送信息
char tempBuf[200];//存放中間數(shù)據(jù)
SOCKADDR_IN addrClient;//在接收的時候,獲取對方的信息,地址結構體的變量
int len=sizeof(SOCKADDR);//初始化,長度為,地址結構體的長度
while(1)//保證通訊過程能夠持續(xù)進行
{
//等待并接收數(shù)據(jù)
recvfrom(sockSrv,recvBuf,100,0,(SOCKADDR*)&addrClient,&len);
//套接字,接收數(shù)據(jù)buf,其長度,,地址結構的指針,指向整型的指針主要用來返回所接收的地址長度
if('q'==recvBuf[0])//判斷接收的數(shù)據(jù)第一個字符是q嗎,
{
sendto(sockSrv,"q",strlen("q")+1,0,(SOCKADDR*)&addrClient,len);
//若是,服務器也發(fā)一個q字符,套接字,q,長度多發(fā)一個字節(jié),,地址用剛剛得到的,最后一個是地址結構的長度,通過len可得
printf("Chat end!\n");
break;
}
//如果接收的不是q,那么對數(shù)據(jù)進行一個格式化,放到tempBuf中,點分十進制的ip地址,所接收的數(shù)據(jù)。
sprintf(tempBuf,"%s say : %s",inet_ntoa(addrClient.sin_addr),recvBuf);
printf("%s\n",tempBuf);//將數(shù)據(jù)打印輸出
//發(fā)送數(shù)據(jù)
printf("please input data:\n");
gets(sendBuf);//從標準輸入流中獲取一行數(shù)據(jù),當我們輸入一行數(shù)據(jù),以回車,就把數(shù)據(jù)放到指定的內存指針中了。
sendto(sockSrv,sendBuf,strlen(sendBuf)+1,0,(SOCKADDR*)&addrClient,len);
//套接字,所要發(fā)送的數(shù)據(jù),(這個是數(shù)據(jù)長度,用strlen獲?。┒喟l(fā)一個字節(jié),所發(fā)送的地址,
}
//關閉套接字
closesocket(sockSrv);
WSACleanup();//終止對套接字的使用
}
NetClient.cpp
//客戶端
#include<Winsock2.h>
#include<stdio.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;
}
//創(chuàng)建套接字
SOCKET sockClient = socket(AF_INET,SOCK_DGRAM,0);
//,類型(數(shù)據(jù)報),自動選擇合適協(xié)議
SOCKADDR_IN addrSrv;
//基于upd的客戶端(發(fā)送端),不需要去綁定,但是需要設置發(fā)送到對方機器的地址信息
//服務器端的地址信息,因為在本機上,所以還是127.0.0.1),用inet_addr將點分十進制轉換成ulang類型
addrSrv.sin_addr.S_un.S_addr = inet_addr("127.0.0.1");
addrSrv.sin_family = AF_INET;
addrSrv.sin_port = htons(6000);//設置服務器端程序在哪個端口上等待數(shù)據(jù)
char recvBuf[100];//接收數(shù)據(jù)
char sendBuf[100];//發(fā)送數(shù)據(jù)
char tempBuf[200];//臨時數(shù)據(jù)的存儲
int len = sizeof(SOCKADDR);//接收所返回的地址結構的長度
while(1)
{
//發(fā)送數(shù)據(jù)
printf("Please input data:\n");
gets(sendBuf);
sendto(sockClient,sendBuf,strlen(sendBuf)+1,0,(SOCKADDR*)&addrSrv,len);
//等待并接收數(shù)據(jù)
recvfrom(sockClient,recvBuf,100,0,(SOCKADDR*)&addrSrv,&len);
if('q'==recvBuf[0])
{
sendto(sockClient,"q",strlen("q")+1,0,(SOCKADDR*)&addrSrv,len);
printf("Chat end!\n");
break;
}
sprintf(tempBuf,"%s say : %s",inet_ntoa(addrSrv.sin_addr),recvBuf);
//服務器端ip地址信息(格式化),接收的數(shù)據(jù)
printf("%s\n",tempBuf);
}
//關閉套接字
closesocket(sockClient);
WSACleanup();
}
ws2_32.lib


以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關文章
Mingw64編譯wxWidgets 3.0.2常見錯誤分析
這篇文章主要介紹了Mingw64編譯wxWidgets 3.0.2常見錯誤分析,需要的朋友可以參考下2016-11-11

