1、苏州大学实验报告 院、系 文正学院 年级专业 12物联网 姓名 高成波 学号 1217443036 课程名称 网络程序设计 成绩 指导教师 陆建德 同组实验者 无 实验日期 第5页,共5页 教务处制 实 验 名 称 实验二 控制台方式Winsock数据报套接字广播通信 一. 实验内容(要求先完成题目,然后上机验证) 本实验利用Winsock API进行控制台方式下数据报套接字的广播通信程序设计。参照实验2讲义中的操作步骤,完成该程序的设计,并上机调试。要求可以实现本机与同一网络内其它主机之间的广播通信。 实验报告内容包括主
2、要的实验代码、必要的注释或另外的说明文档以及实验结果与分析。
发送端:
#include
3、BUF_SZIE]; //发送数据缓冲区 //初始化套结字动态库 if (WSAStartup(MAKEWORD(2,2), &wsd) != 0) { printf("WSAStartup failed!\n"); return 1; } //创建套接字 s = socket(AF_INET, SOCK_DGRAM, 0); if (s == INVALID_SOCKET) { printf("socket() failed; %d\n", WSAGetLastError()); WSACleanup();//释放套接字资源
4、 return 1; } BOOL bBroadcast = true; setsockopt(s, SOL_SOCKET, SO_BROADCAST, (char*)&bBroadcast, sizeof(BOOL)); ZeroMemory(buf, BUF_SZIE); //服务器地址 servAddr.sin_family =AF_INET; servAddr.sin_addr.s_addr = inet_addr("127.0.0.1"); ser
5、vAddr.sin_port = htons((short)5000); int nServAddlen = sizeof(servAddr); SOCKADDR_IN bcast; bcast.sin_addr.s_addr = INADDR_BROADCAST; bcast.sin_family = AF_INET; bcast.sin_port = htons((short)5000); //发送数据 printf(" 开始向网络中发送广播数据... \n \n"); char sz[] = "This is ju
6、st a broadcast test. I am Lao.\n\n"; while(TRUE) { sendto(s, sz, strlen(sz), 0, (sockaddr*)&bcast, sizeof(bcast)); Sleep(5000); } if(sendto(s, buf, BUF_SZIE, 0, (SOCKADDR*)&servAddr, nServAddlen) == SOCKET_ERROR) { printf("recvfrom() failed: %d\n", WSAGetLastError()); clos
7、esocket(s); //关闭套接字
WSACleanup(); //释放套接字资源
return 1;
}
closesocket(s); //关闭套接字
WSACleanup(); //释放套接字资源
return 0;
}
接收端:
#include
8、DATA wsd; //WSADATA变量 SOCKET s; //套接字 SOCKADDR_IN servAddr; //服务器地址 char buf[BUF_SZIE]; //接收数据缓冲区 //初始化套结字动态库 if (WSAStartup(MAKEWORD(2,2), &wsd) != 0) { printf("WSAStartup failed!\n"); return 1; } //创建套接字 s = socket(AF_INET, SOCK_DGRAM, 0); if (s == INVA
9、LID_SOCKET) { printf("socket() failed; %d\n", WSAGetLastError()); WSACleanup();//释放套接字资源 return 1; } int nErrCode; //返回值 int nBufLen; //接收数据缓冲区大小 int nOptlen = sizeof(nBufLen); //获取接收数据缓冲区大小 nErrCode = getsockopt(s, SOL_SOCKET, SO_RCVBUF,(char*)&nBufLen, &nOptlen); if (SO
10、CKET_ERROR == nErrCode) { //处理失败 } //设置接收数据缓冲区为原来的10倍 nBufLen *= 10; nErrCode = setsockopt(s, SOL_SOCKET, SO_RCVBUF,(char*)&nBufLen, nOptlen); if (SOCKET_ERROR == nErrCode) { //失败处理 } //检查设置系统接收数据缓冲区是否成功 int uiNewRcvBuf; getsockopt(s, SOL_SOCKET, SO_RCVBUF,(char*)&uiN
11、ewRcvBuf, &nOptlen); if (SOCKET_ERROR == nErrCode || uiNewRcvBuf != nBufLen) { //失败处理 } //服务器地址 servAddr.sin_family = AF_INET; servAddr.sin_port = htons((short)5000); //端口 servAddr.sin_addr.s_addr = htonl(INADDR_ANY); //IP //绑定 if (bind(s, (SOCKADDR *)&servAddr, sizeof(
12、servAddr)) == SOCKET_ERROR) { printf("bind() failed: %d\n", WSAGetLastError()); closesocket(s); //关闭套接字 WSACleanup(); //释放套接字资源 return 1; } SOCKADDR_IN bcast; bcast.sin_addr.s_addr = INADDR_BROADCAST; bcast.sin_family = AF_INET; bcast.sin_port = htons((short)5000);
13、//接收数据 printf(" 开始接收广播数据... \n\n"); SOCKADDR_IN addrRemote; int nLen = sizeof(addrRemote); char sz[256]; while(TRUE) { int nRet = recvfrom(s, sz, 256, 0, (sockaddr*)&addrRemote, &nLen); if(nRet > 0) { sz[nRet] = '\0'; printf(sz); } } closesocket(s); //关闭套接字 WSACleanup(); //释放套接字资源 return 0; } 实验结果:设置广播之后,可以向教室内的所有同学的机子发送广播,他们可以接受到我发送的信息,同时同学们的电脑也向其他同学发送广播,我也可以接收到别人的广播。 结果分析:本实验关键在于设置广播端口,接收端和发送端要一致,并且在模版程序的基础上要加入广播套接字,两边都要加,并且用UDP协议。这样,教室里的同学就可以通过广播接收到发送的信息了。






