由于代码的注释已经很详尽了,所以这里不再作过多说明.仅仅贴出代码和结果图.

值得注意的是必须先启动server程序再启动client.

Server:

 #include <WINSOCK2.H>    //套接字库
#include <stdio.h> #define PORT 6000 //服务器端口
#define MSGSIZE 1024 //收发缓冲区的大小 #pragma comment(lib, "ws2_32.lib") //链接静态库 DWORD WINAPI FunThread(LPVOID); //创建一个线程,专门用来接收数据 SOCKET sClient; //连接所用套节字
SOCKET sListen; //监听套接字
SOCKADDR_IN client; //保存客户的地址信息
int iaddrSize = sizeof(SOCKADDR_IN); int main()
{ WSADATA wsaData; //WSADATA结构体中主要包含了系统所支持的Winsock版本信息
SOCKADDR_IN local; //定义本地套接字地址
char s_Message[MSGSIZE]; //收发缓冲区 WSAStartup(0x0202, &wsaData); //初始化套接字库 sListen = socket(AF_INET, SOCK_STREAM, IPPROTO_TCP);//创建服务器监听套节字。TCP协议 local.sin_family = AF_INET; //AF_INET指明使用TCP/IP协议族
local.sin_port = htons(PORT);//指明连接服务器的端口号
local.sin_addr.s_addr = htonl(INADDR_ANY);//自动获取本机地址 bind(sListen, (struct sockaddr *)&local, sizeof(SOCKADDR_IN));//地址绑定到套接字 listen(sListen, );//开始监听 sClient = accept(sListen, (struct sockaddr *)&client, &iaddrSize);//建立连接,返回用于连接的套接字
printf("Accepte client:%s:%d\n", inet_ntoa(client.sin_addr), ntohs(client.sin_port));//输出客户端的IP地址和端口 HANDLE hThread=CreateThread(NULL,,FunThread,,,);//运行至此创建专门的接收线程用于接收客户端发送
//的数据,在监听主线程上创建一个新的数据接收线程
CloseHandle(hThread);//关闭线程句柄 //用于从服务器端向客户端发送数据
while (TRUE)
{
printf("Server Send:");
//从键盘输入
gets(s_Message);
//发送数据
send(sClient, s_Message, strlen(s_Message), );
}
return ;
} //当接收数据时调用此线程函数
DWORD WINAPI FunThread(LPVOID)
{
char c_Message[MSGSIZE]; //接收数据缓冲区
int ret; //接收字节的个数
while (TRUE)
{
ret = recv(sClient, c_Message, MSGSIZE, );//接收数据到缓冲区 //判断是否成功接收,如果未成功接收则重启监听,将原缓冲区的数据归零
if(ret==SOCKET_ERROR)
{
printf("\nclient is closed!"); sClient = accept(sListen, (struct sockaddr *)&client, &iaddrSize);//重新开始监听
printf("\nAccepte new client:%s:%d", inet_ntoa(client.sin_addr), ntohs(client.sin_port));
memset(c_Message,,);//将原来的client message归零
continue;
}
c_Message[ret] = '\0';
printf("\nReceived: %s\n", c_Message);
}
return ;
}<strong>
</strong>

Client:

 #include <WINSOCK2.H> //套接字库
#include <stdio.h> #define SERVER_ADDRESS "127.0.0.1" //服务器端IP地址,由于服务也在本地机器上所以用环回地址127.0.0.1 #define PORT 6000 //客户端绑定端口
#define MSGSIZE 1024 //客户端接收数据缓冲区大小
#pragma comment(lib, "ws2_32.lib") DWORD WINAPI FunThread(LPVOID); //对于客户端接收数据的线程函数 SOCKET sClient; //客户端套接字
SOCKADDR_IN server; //服务器端套接字 int main()
{
WSADATA wsaData;
char c_Message[MSGSIZE]; //数据缓冲区 WSAStartup(0x0202, &wsaData); //初始化套接字库 sClient = socket(AF_INET, SOCK_STREAM, IPPROTO_TCP); //创建客户端套接字 memset(&server, , sizeof(SOCKADDR_IN)); //先将保存地址的server置为全0
server.sin_family = PF_INET; //声明地址格式是TCP/IP地址格式
server.sin_port = htons(PORT); //指明连接服务器的端口号
server.sin_addr.s_addr = inet_addr(SERVER_ADDRESS); //指明连接服务器的IP地址 connect(sClient, (struct sockaddr *)&server, sizeof(SOCKADDR_IN)); //连到刚才指明的服务器上 HANDLE hThread=CreateThread(NULL,,FunThread,,,);;//客户端开辟接收数据线程
CloseHandle(hThread); //客户端向服务器发送数据
while (TRUE)
{
printf("Client Send:");
gets(c_Message); send(sClient, c_Message, strlen(c_Message), );
if(!strcmp(c_Message,"exit"))//client自身退出
exit();
} // 释放连接和进行结束工作
closesocket(sClient);
WSACleanup();
return ;
} //接收线程函数
DWORD WINAPI FunThread(LPVOID)
{
char s_Message[MSGSIZE];//定义接收缓冲区
int ret;
while (TRUE)
{
ret = recv(sClient, s_Message, MSGSIZE, );//接收服务器端的数据 //判断是否接收
if(ret==SOCKET_ERROR)
{
printf("\nServer is closed!\n");
exit();
}
s_Message[ret] = '\0';
//显示接收数据
printf("\nReceived: %s\n", s_Message); //如果服务器端发送exit则client退出
if(!strcmp(s_Message,"exit"))//server让client退出
exit();
}
return ;
}<strong>
</strong>

运行结果如下:



基于TCP套接字实现的简单Demo的更多相关文章

  1. unix网络编程第四章----基于TCP套接字编程

    为了执行网络I/O操作.进程必须做的第一件事情就是调用Socket函数.指定期待的通信协议 #include<sys/socket.h> int socket(int family,int ...

  2. Python之路(第三十一篇) 网络编程:简单的tcp套接字通信、粘包现象

    一.简单的tcp套接字通信 套接字通信的一般流程 服务端 server = socket() #创建服务器套接字 server.bind() #把地址绑定到套接字,网络地址加端口 server.lis ...

  3. Python网络编程之TCP套接字简单用法示例

    Python网络编程之TCP套接字简单用法示例 本文实例讲述了Python网络编程之TCP套接字简单用法.分享给大家供大家参考,具体如下: 上学期学的计算机网络,因为之前还未学习python,而jav ...

  4. TCP套接字编程模型及实例

    摘要:     本文讲述了TCP套接字编程模块,包括服务器端的创建套接字.绑定.监听.接受.读/写.终止连接,客户端的创建套接字.连接.读/写.终止连接.先给出实例,进而结合代码分析. PS:本文权当 ...

  5. Python网络编程02 /基于TCP、UDP协议的socket简单的通信、字符串转bytes类型

    Python网络编程02 /基于TCP.UDP协议的socket简单的通信.字符串转bytes类型 目录 Python网络编程02 /基于TCP.UDP协议的socket简单的通信.字符串转bytes ...

  6. TCP套接字编程

    一.套接字(socket)函数 图1给出了在一个TCP客户与服务器通信的流程.服务器首先启动,稍后某个客户启动,它试图连接到服务器.假设客户给服务器发送一个请求,服务器处理该请求,并且给客户发回一个相 ...

  7. 【UNIX网络编程(二)】基本TCP套接字编程函数

    基于TCP客户/server程序的套接字函数图例如以下: 运行网络I/O.一个进程必须做的第一件事就是调用socket函数.指定期望的通信协议类型. #include <sys/socket.h ...

  8. 套接字编程相关函数(2:TCP套接字编程相关函数)

    本文摘录自<UNIX网络编程 卷1>. 基本套接字函数 socket函数 为了执行网络I/O,一个进程必须做的第一件事就是调用socket函数,指定期望的通信协议类型.其定义如下: #in ...

  9. LINUX TCP套接字详细配置

    提高服务器的负载能力,是一个永恒的话题.在一台服务器CPU和内存资源额定有限的情况下,最大的压榨服务器的性能,是最终的目的.要提高 Linux系统下的负载能力,可以先启用Apache的Worker模式 ...

随机推荐

  1. JavaScriptSerializer类 对象序列化为JSON,JSON反序列化为对象

    JavaScriptSerializer 类由异步通信层内部使用,用于序列化和反序列化在浏览器和 Web 服务器之间传递的数据.说白了就是能够直接将一个C#对象传送到前台页面成为javascript对 ...

  2. CircleImageView自定义圆形控件的使用

    1.自定义圆形控件github地址: https://github.com/hdodenhof/CircleImageView 主要的类: package de.hdodenhof.circleima ...

  3. css案例学习之table tr th td ul li实现日历

    效果 代码 <html> <head> <title>Calendar</title> <style> <!-- .month { b ...

  4. UESTC_秋实大哥与妹纸 2015 UESTC Training for Data Structures<Problem F>

    F - 秋实大哥与妹纸 Time Limit: 3000/1000MS (Java/Others)     Memory Limit: 1500/1500KB (Java/Others) Submit ...

  5. Windows SVN变化邮件通知(Python2.7实现)

    1,新增文件post-commit.bat 内容: rem REPOS-PATH (the path to this repository) set REPOS=%1 rem REV (the num ...

  6. 利用Python完成一个小游戏:随机挑选一个单词,并对其进行乱序,玩家要猜出原始单词

    一 Python的概述以及游戏的内容 Python是一种功能强大且易于使用的编程语言,更接近人类语言,以至于人们都说它是“以思考的速度编程”:Python具备现代编程语言所应具备的一切功能:Pytho ...

  7. Virtual Friends(并查集+map)

    Virtual Friends Time Limit: 4000/2000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)T ...

  8. 为啥NSString的属性要用copy而不用retain

    之前学习生活中,知道NSString的属性要用copy而不用retain,可是不知道为啥,这两天我研究了一下,然后最终明确了. 详细原因是由于用copy比用retain安全,当是NSString的时候 ...

  9. Android应用程序组件Content Provider应用实例

    文章转载至CSDN社区罗升阳的安卓之旅,原文地址:http://blog.csdn.net/luoshengyang/article/details/6950440 文简要介绍了Android应用程序 ...

  10. [记录]关于vertical-align单/多选框与说明文字对齐效果

    效果图:    第一张使用label标签,第二张没有使用.. 使用label标签,middle对齐方式的单选框下降了1px 而没有使用label标签,sub对齐方式的 却 居 中 了 =_= 不太理解 ...