一。程序运行效果图

二。程序源代码

三。程序设计相关基础知识

1.计算机网络
    2.IP地址
    3.协议
    4.网络体系结构
    5.TCP/IP体系结构与特点
    6.客户机/服务器模式
    7.TCP/IP特点
    8.套接字的引入
    9.面向 连接/无连接 的套接字的系统调用时序图/流程图

一。程序运行效果图

二。程序源代码

[cpp] view plaincopyprint?
  1. // server.cpp
  2. #include <iostream>
  3. #include <cstdio>
  4. #include <Winsock2.h>
  5. using namespace std;
  6. int main()
  7. {
  8. // 加载socket动态链接库(dll)
  9. WORD wVersionRequested;
  10. WSADATA wsaData;    // 这结构是用于接收Wjndows Socket的结构信息的
  11. int err;
  12. wVersionRequested = MAKEWORD( 1, 1 );   // 请求1.1版本的WinSock库
  13. err = WSAStartup( wVersionRequested, &wsaData );
  14. if ( err != 0 ) {
  15. return -1;          // 返回值为零的时候是表示成功申请WSAStartup
  16. }
  17. if ( LOBYTE( wsaData.wVersion ) != 1 || HIBYTE( wsaData.wVersion ) != 1 ) {
  18. // 检查这个低字节是不是1,高字节是不是1以确定是否我们所请求的1.1版本
  19. // 否则的话,调用WSACleanup()清除信息,结束函数
  20. WSACleanup( );
  21. return -1;
  22. }
  23. // 创建socket操作,建立流式套接字,返回套接字号sockSrv
  24. // SOCKET socket(int af, int type, int protocol);
  25. // 第一个参数,指定地址簇(TCP/IP只能是AF_INET,也可写成PF_INET)
  26. // 第二个,选择套接字的类型(流式套接字),第三个,特定地址家族相关协议(0为自动)
  27. SOCKET sockSrv = socket(AF_INET, SOCK_STREAM, 0);
  28. // 套接字sockSrv与本地地址相连
  29. // int bind(SOCKET s, const struct sockaddr* name, int namelen);
  30. // 第一个参数,指定需要绑定的套接字;
  31. // 第二个参数,指定该套接字的本地地址信息,该地址结构会随所用的网络协议的不同而不同
  32. // 第三个参数,指定该网络协议地址的长度
  33. // PS: struct sockaddr{ u_short sa_family; char sa_data[14];};
  34. //                      sa_family指定该地址家族, sa_data起到占位占用一块内存分配区的作用
  35. //     在TCP/IP中,可使用sockaddr_in结构替换sockaddr,以方便填写地址信息
  36. //
  37. //     struct sockaddr_in{ short sin_family; unsigned short sin_port; struct in_addr sin_addr; char sin_zero[8];};
  38. //     sin_family表示地址族,对于IP地址,sin_family成员将一直是AF_INET。
  39. //     sin_port指定将要分配给套接字的端口。
  40. //     sin_addr给出套接字的主机IP地址。
  41. //     sin_zero[8]给出填充数,让sockaddr_in与sockaddr结构的长度一样。
  42. //     将IP地址指定为INADDR_ANY,允许套接字向任何分配给本地机器的IP地址发送或接收数据。
  43. //     如果想只让套接字使用多个IP中的一个地址,可指定实际地址,用inet_addr()函数。
  44. SOCKADDR_IN addrSrv;
  45. addrSrv.sin_addr.S_un.S_addr = htonl(INADDR_ANY); // 将INADDR_ANY转换为网络字节序,调用 htonl(long型)或htons(整型)
  46. addrSrv.sin_family = AF_INET;
  47. addrSrv.sin_port = htons(6000);
  48. bind(sockSrv, (SOCKADDR*)&addrSrv, sizeof(SOCKADDR)); // 第二参数要强制类型转换
  49. // 将套接字设置为监听模式(连接请求), listen()通知TCP服务器准备好接收连接
  50. // int listen(SOCKET s,  int backlog);
  51. // 第一个参数指定需要设置的套接字,第二个参数为(等待连接队列的最大长度)
  52. listen(sockSrv, 10);
  53. // accept(),接收连接,等待客户端连接
  54. // SOCKET accept(  SOCKET s,  struct sockaddr* addr,  int* addrlen);
  55. // 第一个参数,接收一个处于监听状态下的套接字
  56. // 第二个参数,sockaddr用于保存客户端地址的信息
  57. // 第三个参数,用于指定这个地址的长度
  58. // 返回的是向与这个监听状态下的套接字通信的套接字
  59. // 客户端与用户端进行通信
  60. // send(), 在套接字上发送数据
  61. // int send( SOCKET s,  const char* buf,  int len,  int flags);
  62. // 第一个参数,需要发送信息的套接字,
  63. // 第二个参数,包含了需要被传送的数据,
  64. // 第三个参数是buffer的数据长度,
  65. // 第四个参数,一些传送参数的设置
  66. // recv(), 在套接字上接收数据
  67. // int recv(  SOCKET s,  char* buf,  int len,  int flags);
  68. // 第一个参数,建立连接后的套接字,
  69. // 第二个参数,接收数据
  70. // 第三个参数,接收数据的长度,
  71. // 第四个参数,一些传送参数的设置
  72. SOCKADDR_IN  addrClient;
  73. int len = sizeof(SOCKADDR);
  74. while(true){    // 不断等待客户端请求的到来
  75. SOCKET sockConn = accept(sockSrv, (SOCKADDR*)&addrClient, &len);
  76. char sendBuf[100];
  77. sprintf(sendBuf, "Welcome %s to the server program~ \nNow, let's start talking...\n", inet_ntoa(addrClient.sin_addr));
  78. send(sockConn, sendBuf, strlen(sendBuf)+1, 0);  // 发送显示欢迎信息
  79. char recvBuf[100];
  80. recv(sockConn, recvBuf, 100, 0);
  81. printf("%s\n", recvBuf);        // 接收第一次信息
  82. char * sockConnName = "Client";
  83. printf("我们可以聊五句话");
  84. int n = 5;
  85. while(n--){
  86. printf("还剩%d次:\n", n+1);
  87. char recvBuf[100];
  88. recv(sockConn, recvBuf, 100, 0);
  89. printf("%s Says: %s\n", sockConnName, recvBuf);     // 接收信息
  90. char talk[100];
  91. printf("Please enter what you want to say next(\"quit\"to exit):");
  92. gets(talk);
  93. send(sockConn, talk, strlen(talk)+1, 0);            // 发送信息
  94. printf("\n");
  95. }
  96. printf("\nEnd talking... \n");
  97. closesocket(sockConn);
  98. }
  99. printf("\n");
  100. system("pause");
  101. return 0;
  102. }
// server.cpp#include <iostream>
#include <cstdio>
#include <Winsock2.h>using namespace std;int main()
{
// 加载socket动态链接库(dll)WORD wVersionRequested;WSADATA wsaData;    // 这结构是用于接收Wjndows Socket的结构信息的int err;wVersionRequested = MAKEWORD( 1, 1 );   // 请求1.1版本的WinSock库err = WSAStartup( wVersionRequested, &wsaData );if ( err != 0 ) {return -1;            // 返回值为零的时候是表示成功申请WSAStartup}if ( LOBYTE( wsaData.wVersion ) != 1 ||   HIBYTE( wsaData.wVersion ) != 1 ) {// 检查这个低字节是不是1,高字节是不是1以确定是否我们所请求的1.1版本// 否则的话,调用WSACleanup()清除信息,结束函数WSACleanup( );return -1; }// 创建socket操作,建立流式套接字,返回套接字号sockSrv// SOCKET socket(int af, int type, int protocol);// 第一个参数,指定地址簇(TCP/IP只能是AF_INET,也可写成PF_INET)// 第二个,选择套接字的类型(流式套接字),第三个,特定地址家族相关协议(0为自动)SOCKET sockSrv = socket(AF_INET, SOCK_STREAM, 0);    // 套接字sockSrv与本地地址相连// int bind(SOCKET s, const struct sockaddr* name, int namelen);// 第一个参数,指定需要绑定的套接字;// 第二个参数,指定该套接字的本地地址信息,该地址结构会随所用的网络协议的不同而不同// 第三个参数,指定该网络协议地址的长度// PS: struct sockaddr{ u_short sa_family; char sa_data[14];};//                      sa_family指定该地址家族, sa_data起到占位占用一块内存分配区的作用//     在TCP/IP中,可使用sockaddr_in结构替换sockaddr,以方便填写地址信息// //     struct sockaddr_in{ short sin_family; unsigned short sin_port; struct in_addr sin_addr; char sin_zero[8];};//     sin_family表示地址族,对于IP地址,sin_family成员将一直是AF_INET。//     sin_port指定将要分配给套接字的端口。//     sin_addr给出套接字的主机IP地址。//     sin_zero[8]给出填充数,让sockaddr_in与sockaddr结构的长度一样。//     将IP地址指定为INADDR_ANY,允许套接字向任何分配给本地机器的IP地址发送或接收数据。//     如果想只让套接字使用多个IP中的一个地址,可指定实际地址,用inet_addr()函数。SOCKADDR_IN addrSrv;addrSrv.sin_addr.S_un.S_addr = htonl(INADDR_ANY); // 将INADDR_ANY转换为网络字节序,调用 htonl(long型)或htons(整型)addrSrv.sin_family = AF_INET;addrSrv.sin_port = htons(6000);bind(sockSrv, (SOCKADDR*)&addrSrv, sizeof(SOCKADDR)); // 第二参数要强制类型转换// 将套接字设置为监听模式(连接请求), listen()通知TCP服务器准备好接收连接// int listen(SOCKET s,  int backlog);// 第一个参数指定需要设置的套接字,第二个参数为(等待连接队列的最大长度)listen(sockSrv, 10);// accept(),接收连接,等待客户端连接// SOCKET accept(  SOCKET s,  struct sockaddr* addr,  int* addrlen);// 第一个参数,接收一个处于监听状态下的套接字// 第二个参数,sockaddr用于保存客户端地址的信息// 第三个参数,用于指定这个地址的长度// 返回的是向与这个监听状态下的套接字通信的套接字// 客户端与用户端进行通信// send(), 在套接字上发送数据// int send( SOCKET s,  const char* buf,  int len,  int flags);// 第一个参数,需要发送信息的套接字,// 第二个参数,包含了需要被传送的数据,// 第三个参数是buffer的数据长度,// 第四个参数,一些传送参数的设置// recv(), 在套接字上接收数据// int recv(  SOCKET s,  char* buf,  int len,  int flags);// 第一个参数,建立连接后的套接字,// 第二个参数,接收数据// 第三个参数,接收数据的长度,// 第四个参数,一些传送参数的设置SOCKADDR_IN  addrClient;int len = sizeof(SOCKADDR);while(true){  // 不断等待客户端请求的到来SOCKET sockConn = accept(sockSrv, (SOCKADDR*)&addrClient, &len);char sendBuf[100];sprintf(sendBuf, "Welcome %s to the server program~ \nNow, let's start talking...\n", inet_ntoa(addrClient.sin_addr));send(sockConn, sendBuf, strlen(sendBuf)+1, 0);  // 发送显示欢迎信息char recvBuf[100];recv(sockConn, recvBuf, 100, 0);printf("%s\n", recvBuf);     // 接收第一次信息char * sockConnName = "Client";printf("我们可以聊五句话");int n = 5;while(n--){printf("还剩%d次:\n", n+1);char recvBuf[100];recv(sockConn, recvBuf, 100, 0);printf("%s Says: %s\n", sockConnName, recvBuf);        // 接收信息char talk[100];printf("Please enter what you want to say next(\"quit\"to exit):");gets(talk);send(sockConn, talk, strlen(talk)+1, 0);           // 发送信息printf("\n");}     printf("\nEnd talking... \n");closesocket(sockConn);}printf("\n");system("pause");return 0;
}
[cpp] view plaincopyprint?
  1. // client.cpp
  2. #include <iostream>
  3. #include <cstdio>
  4. #include <Winsock2.h>
  5. using namespace std;
  6. int main()
  7. {
  8. // 加载socket动态链接库(dll)
  9. WORD wVersionRequested;
  10. WSADATA wsaData;    // 这结构是用于接收Wjndows Socket的结构信息的
  11. int err;
  12. wVersionRequested = MAKEWORD( 1, 1 );   // 请求1.1版本的WinSock库
  13. err = WSAStartup( wVersionRequested, &wsaData );
  14. if ( err != 0 ) {
  15. return -1;          // 返回值为零的时候是表示成功申请WSAStartup
  16. }
  17. if ( LOBYTE( wsaData.wVersion ) != 1 || HIBYTE( wsaData.wVersion ) != 1 ) {
  18. // 检查这个低字节是不是1,高字节是不是1以确定是否我们所请求的1.1版本
  19. // 否则的话,调用WSACleanup()清除信息,结束函数
  20. WSACleanup( );
  21. return -1;
  22. }
  23. // 创建socket操作,建立流式套接字,返回套接字号sockClient
  24. // SOCKET socket(int af, int type, int protocol);
  25. // 第一个参数,指定地址簇(TCP/IP只能是AF_INET,也可写成PF_INET)
  26. // 第二个,选择套接字的类型(流式套接字),第三个,特定地址家族相关协议(0为自动)
  27. SOCKET sockClient = socket(AF_INET, SOCK_STREAM, 0);
  28. // 将套接字sockClient与远程主机相连
  29. // int connect( SOCKET s,  const struct sockaddr* name,  int namelen);
  30. // 第一个参数:需要进行连接操作的套接字
  31. // 第二个参数:设定所需要连接的地址信息
  32. // 第三个参数:地址的长度
  33. SOCKADDR_IN addrSrv;
  34. addrSrv.sin_addr.S_un.S_addr = inet_addr("127.0.0.1");      // 本地回路地址是127.0.0.1;
  35. addrSrv.sin_family = AF_INET;
  36. addrSrv.sin_port = htons(6000);
  37. connect(sockClient, (SOCKADDR*)&addrSrv, sizeof(SOCKADDR));
  38. char recvBuf[100];
  39. recv(sockClient, recvBuf, 100, 0);
  40. printf("%s\n", recvBuf);
  41. send(sockClient, "Attention: A Client has enter...\n", strlen("Attention: A Client has enter...\n")+1, 0);
  42. printf("我们可以聊五句话");
  43. int n = 5;
  44. do{
  45. printf("\n还剩%d次:", n);
  46. char talk[100];
  47. printf("\nPlease enter what you want to say next(\"quit\"to exit):");
  48. gets(talk);
  49. send(sockClient, talk, strlen(talk)+1, 0);          // 发送信息
  50. char recvBuf[100];
  51. recv(sockClient, recvBuf, 100, 0);
  52. printf("%s Says: %s\n", "Server", recvBuf);     // 接收信息
  53. }while(--n);
  54. printf("End linking...\n");
  55. closesocket(sockClient);
  56. WSACleanup();   // 终止对套接字库的使用
  57. printf("\n");
  58. system("pause");
  59. return 0;
  60. }
// client.cpp#include <iostream>
#include <cstdio>
#include <Winsock2.h>using namespace std;int main()
{
// 加载socket动态链接库(dll)WORD wVersionRequested;WSADATA wsaData;    // 这结构是用于接收Wjndows Socket的结构信息的int err;wVersionRequested = MAKEWORD( 1, 1 );   // 请求1.1版本的WinSock库err = WSAStartup( wVersionRequested, &wsaData );if ( err != 0 ) {return -1;            // 返回值为零的时候是表示成功申请WSAStartup}if ( LOBYTE( wsaData.wVersion ) != 1 ||   HIBYTE( wsaData.wVersion ) != 1 ) {// 检查这个低字节是不是1,高字节是不是1以确定是否我们所请求的1.1版本// 否则的话,调用WSACleanup()清除信息,结束函数WSACleanup( );return -1; }// 创建socket操作,建立流式套接字,返回套接字号sockClient// SOCKET socket(int af, int type, int protocol);// 第一个参数,指定地址簇(TCP/IP只能是AF_INET,也可写成PF_INET)// 第二个,选择套接字的类型(流式套接字),第三个,特定地址家族相关协议(0为自动)SOCKET sockClient = socket(AF_INET, SOCK_STREAM, 0);// 将套接字sockClient与远程主机相连// int connect( SOCKET s,  const struct sockaddr* name,  int namelen);// 第一个参数:需要进行连接操作的套接字// 第二个参数:设定所需要连接的地址信息// 第三个参数:地址的长度SOCKADDR_IN addrSrv;addrSrv.sin_addr.S_un.S_addr = inet_addr("127.0.0.1");      // 本地回路地址是127.0.0.1; addrSrv.sin_family = AF_INET;addrSrv.sin_port = htons(6000);connect(sockClient, (SOCKADDR*)&addrSrv, sizeof(SOCKADDR));char recvBuf[100];recv(sockClient, recvBuf, 100, 0);printf("%s\n", recvBuf);send(sockClient, "Attention: A Client has enter...\n", strlen("Attention: A Client has enter...\n")+1, 0);printf("我们可以聊五句话");int n = 5;do{printf("\n还剩%d次:", n);char talk[100];printf("\nPlease enter what you want to say next(\"quit\"to exit):");gets(talk);send(sockClient, talk, strlen(talk)+1, 0);         // 发送信息char recvBuf[100];recv(sockClient, recvBuf, 100, 0);printf("%s Says: %s\n", "Server", recvBuf);      // 接收信息}while(--n);printf("End linking...\n");closesocket(sockClient);WSACleanup();   // 终止对套接字库的使用printf("\n");system("pause");return 0;
}

三。程序设计相关基础知识

1.计算机网络
2.IP地址
3.协议
4.网络体系结构

5.TCP/IP体系结构与特点

6.客户机/服务器模式

7.TCP/IP特点

8.套接字的引入

9.面向 连接/无连接 的套接字的系统调用时序图/流程图

from:http://blog.csdn.net/neicole/article/details/7459021

Windows Socket 编程_ 简单的服务器/客户端程序 .相关推荐

  1. Windows Socket 编程_ 简单的服务器/客户端程序

    一.程序运行效果图 二.程序源代码 三.程序设计相关基础知识 1.计算机网络     2.IP地址     3.协议     4.网络体系结构     5.TCP/IP体系结构与特点     6.客户 ...

  2. 服务器端和客户端互发消息,Socket编程实现简单的服务器与客户端互发消息

    socket编程的大致步骤如下: 1.创建服务器端SocketServer,并定义SocketServer的监听端口; 2.ServerSocket调用accept( )方法,是指处于阻塞: 3.创建 ...

  3. windows 下实现socket编程_传送文件

    windows 下实现socket编程_传送文件 其实,Windows下的socket编程与Linux下的类似,这里不再赘述! 参考:http://blog.csdn.net/chudongfang2 ...

  4. Windows Socket编程笔记之最简单的小Demo

    Windows Socket编程的大致过程: 服务器端: ----过程-------------对应的API-------  0.初始化         |  WSAStartup()  1.创建So ...

  5. Socket编程总结—Android手机服务器与多个Android手机客户端之间的通信(非阻塞)

    根据前两周写的关于Socket编程的网络通信的代码,现在对有关知识和注意事项进行总结如下: 1.首先说下Android NIO中有关Socket编程的类: 1)ServerSocketChannel类 ...

  6. java socket通信 客户端_JavaのSocket编程之简单客户端与服务器端通信

    Socket编程之简单客户端与服务器端通信 socket 通常用来实现客户端和服务端的连接,socket 是Tcp/Ip协议的一个十分流行的编程界面,一个socket 由一个Ip地址和一个端口号唯一确 ...

  7. Windows socket之最简单的socket程序

    Windows socket之最简单的socket程序 原文:Windows socket之最简单的socket程序 最简单的服务器的socket程序流程如下(面向连接的TCP连接 ): 1. WSA ...

  8. python socket 实现的简单http服务器

    看这篇文章挺简约的收藏下,只需要替换reg.html  action  http://192.168.56.188:8000   为/ 即可不用改ip地址  post时 预备知识: 关于http 协议 ...

  9. 计算机网络原理 实验1 《Windows Socket编程》

    计算机网络原理 实验1 <Windows Socket编程> 一.实验目的 通过实验,熟悉并掌握计算机Windows 编程的基本知识,进一步加深对课堂所学基本内容的理解,掌握基本的Wind ...

最新文章

  1. 模型大十倍,性能提升几倍?谷歌研究员进行了一番研究
  2. 软件“身份证”频被盗 金山安全呼吁企业加强管理
  3. suse linux 文件只可读,SUSE LINUX下文件系统变只读的问题解决
  4. 从响应式Spring Data存储库流式传输实时更新
  5. 成像数据更好的展示_为什么更多的数据并不总是更好
  6. 卷组删除pv_如何安全的删除Linux LVM中的PV物理卷(硬盘或分区)
  7. 社区团购平台得推社区团购系统 v3.1源码
  8. 3D游戏建模就是那么简单
  9. Python稳基修炼的经典案例10(计算机二级、初学者必会turtle库例题)
  10. 抓包测试步骤XMind
  11. php7类型约束,类型约束 - PHP 7 中文文档
  12. DLNA的使用-天翼高清电视机顶盒镜像投屏
  13. android 常用图像密码,这几种Android图形密码最常用
  14. 【唯美日出win7热门主题】
  15. Android MVP架构实现
  16. Windows 更新错误 0x80073712
  17. 使用fastdfs上传视频并使用FFmpegFrameGrabberFrameGrabber在上传视频时截图作为封面
  18. 计算机中的同步和异步
  19. Java中Properties类的使用
  20. 计算机编程英语单词多少,计算机编程常用英语单词

热门文章

  1. java 字符串xml,解析java中的xml字符串?
  2. C++_STL——deque and vector
  3. idea 快速导入实现父类方法_教你快速吸引精准粉丝实现流量变现的方法
  4. 小程序在wxml里转数字_2020年利用名片小程序开启数字化营销的方法
  5. 浅谈python+requests实现接口自动化
  6. 文件上传至服务器cpu,文件服务器构建指南
  7. cmd指令卸载java_.net 服务 安装 卸载 命令行 bat cmd
  8. web 平台搭建-LAMP-源码包(CentOS-7)
  9. linux lnmp yum,yum安装LNMP
  10. python图像配准的原理_python利用sift和surf进行图像配准