【Echo】实验 -- 实现 C/C++下TCP, 服务器/客户端 通讯
本次实验利用TCP/IP, 语言环境为 C/C++
利用套接字Socket编程,实现Server/CLient 之间简单的通讯。
结果应为类似所示:
下面贴上代码(参考参考...)
Server 部分:
/* TCPServer.cpp - main */ #include <stdlib.h>
#include <stdio.h>
#include <winsock2.h>
#include <time.h>
#include "conio.h" #define QLEN 5
#define WSVERS MAKEWORD(2, 0)
#define BUFLEN 20000
#pragma comment(lib,"ws2_32.lib") //使用winsock 2.2 library
/*------------------------------------------------------------------------
* main - Iterative TCP server for TIME service
*------------------------------------------------------------------------
*/
char buf[];
char buf1[];
char buf2[];
void main(int argc, char *argv[])
/* argc: 命令行参数个数, 例如:C:\> TCPServer 8080
argc=2 argv[0]="TCPServer",argv[1]="8080" */
{
struct sockaddr_in fsin; /* the from address of a client */
SOCKET msock, ssock; /* master & slave sockets */
WSADATA wsadata;
char *service = "";
struct sockaddr_in sin; /* an Internet endpoint address */
int alen; /* from-address length */
char *pts; /* pointer to time string */
// char pts[2000];
time_t now; /* current time */
int cc; WSAStartup(WSVERS, &wsadata); // 加载winsock library。WSVERS指明请求使用的版本。wsadata返回系统实际支持的最高版本
msock = socket(PF_INET, SOCK_STREAM, IPPROTO_TCP); // 创建套接字,参数:因特网协议簇(family),流套接字,TCP协议
// 返回:要监听套接字的描述符或INVALID_SOCKET memset(&sin, , sizeof(sin)); // 从&sin开始的长度为sizeof(sin)的内存清0
sin.sin_family = AF_INET; // 因特网地址簇(INET-Internet)
sin.sin_addr.s_addr = INADDR_ANY; // 监听所有(接口的)IP地址。
sin.sin_port = htons((u_short)atoi(service)); // 监听的端口号。atoi--把ascii转化为int,htons--主机序到网络序(16位)
bind(msock, (struct sockaddr *)&sin, sizeof(sin)); // 绑定监听的IP地址和端口号 listen(msock, ); // 等待建立连接的队列长度为5 while(!_kbhit()){ // 检测是否有按键
alen = sizeof(struct sockaddr); // 取到地址结构的长度
ssock = accept(msock, (struct sockaddr *)&fsin, &alen); // 如果有新的连接请求,返回连接套接字,否则,被阻塞。fsin包含客户端IP地址和端口号 (void) time(&now); // 取得系统时间
pts = ctime(&now); // 把时间转换为字符串
sprintf(buf,"IP :%s 端口号: %d\n",inet_ntoa(fsin.sin_addr),fsin.sin_port);
// sprintf(buf,"%d:%d Hello my friends ! %s",inet_ntoa(sin.sin_addr),fsin.sin_port,pts);
(void) send(ssock, buf, strlen(pts), ); // 把缓冲区(指针,长度)的数据发送出去
printf(" TCP(Server) Echo增强程序 \n\n");
printf(" 时间: %s\n", pts);
printf(" %s\n", buf); // 显示发送字符串
printf("请等待接收数据 :\n"); //flag1:
// printf("\n您还要传送什么?\n");
// printf(" 如果想临时改为接收,请键入 * \n");
// scanf("%s",pts); // if(pts[0] == '*')
// {
// printf("\n请等待接收数据\n");
// sprintf(buf1,"%s",pts);
// (void) send(ssock, buf1, strlen(pts), 0);
// goto flag2;
// }
// sprintf(buf1,"%s",pts);
// (void) send(ssock, buf1, strlen(pts), 0);
// goto flag1;
// ssock = accept(msock, (struct sockaddr *)&fsin, &alen); flag2: cc = recv(ssock, buf1, BUFLEN, );
if(cc == SOCKET_ERROR || cc==)
printf("Error: %d.\n",GetLastError()); //出错。其后必须关闭套接字sock。
else if(cc > ) {
buf1[cc] = '\0'; // ensure null-termination
buf2[cc] = '\0';
// if(buf1[0] == '#')
// {
// printf("\n您接收到的数据为: # , 请传输数据 \n");
// goto flag2;
// }
(void) time(&now);
pts = ctime(&now);
sprintf(buf2,"%s \n %s",pts,buf1);
// strcat(buf2,buf1);
printf("\n您接收到的数据为:");
// printf(" 时间: %s\n", pts);
printf("%s\n", buf2);
printf("\n 将自动把此数据返回给客户!\n");
(void) send(ssock, buf1, strlen(pts), );
goto flag2;
}
(void) closesocket(ssock); // 关闭连接套接字
}
(void) closesocket(msock); // 关闭监听套接字
WSACleanup(); // 卸载winsock library }
Client 部分:
/* TCPClient.cpp */ #include <stdlib.h>
#include <stdio.h>
#include <winsock2.h>
#include <string.h>
#include <time.h>
#include "conio.h"
#define BUFLEN 20000 // 缓冲区大小
#define WSVERS MAKEWORD(2, 0) // 指明版本2.0
#pragma comment(lib,"ws2_32.lib") // 使用winsock 2.0 Llibrary /*------------------------------------------------------------------------
* main - TCP client for TIME service
*------------------------------------------------------------------------
*/
char buf1[BUFLEN+];
char buf[BUFLEN+]; /* buffer for one line of text */
void main(int argc, char *argv[])
{
char *host = "127.0.0.1";
// char *host = "10.4.4.146"; /* server IP to connect */ char *service = ""; /* server port to connect */
struct sockaddr_in sin,fsin; /* an Internet endpoint address */ SOCKET sock,ssock; /* socket descriptor */
int cc,alen; /* recv character count */
char *pts ;
time_t now;
WSADATA wsadata;
WSAStartup(WSVERS, &wsadata); //加载winsock library。WSVERS为请求的版本,wsadata返回系统实际支持的最高版本 sock = socket(PF_INET, SOCK_STREAM, IPPROTO_TCP); //创建套接字,参数:因特网协议簇(family),流套接字,TCP协议 //返回:要监听套接字的描述符或INVALID_SOCKET memset(&sin, , sizeof(sin)); // 从&sin开始的长度为sizeof(sin)的内存清0
sin.sin_family = AF_INET; // 因特网地址簇
sin.sin_addr.s_addr = inet_addr(host); // 服务器IP地址(32位)
sin.sin_port = htons((u_short)atoi(service)); // 服务器端口号
connect(sock, (struct sockaddr *)&sin, sizeof(sin)); // 连接到服务器
// alen = sizeof(struct sockaddr);
// ssock = accept(sock, (struct sockaddr *)&fsin, &alen);
printf(" TCP(Client) Echo增强程序 \n\n");
flag1: cc = recv(sock, buf1, BUFLEN+, ); // cc为接收到的字符的个数(>0)或对方已关闭(=0)或连接出错(<0)
if(cc == SOCKET_ERROR || cc==)
printf("Error: %d.\n",GetLastError()); //出错。其后必须关闭套接字sock。
else if(cc > ) {
buf1[cc] = '\0'; // ensure null-termination
// if(buf[0] == '*')
// {
// printf("\n您接收到的数据为: * , 请传输数据 \n");
// goto flag2;
// }
(void) time(&now); // 取得系统时间
pts = ctime(&now);
printf("您接收到的数据为:\n");
printf(" 时间: %s\n",pts);
printf(" %s\n",buf1); // 显示所接收的字符串
}
goto flag2; flag2: printf("\n您想传送什么?\n");
printf(" 如果想关闭连接,请输入 @ \n");
// printf("\n 如果想临时改为接收,请键入 # \n");
scanf("%s",pts);
if(pts[] == '@')
goto end;
// if(pts[0] == '#')
// {
// printf("\n请等待接收数据\n");
// sprintf(buf1,"%s",pts);
// (void) send(sock, buf1, strlen(pts), 0);
// goto flag1;
// }
sprintf(buf1,"%s",pts);
(void) send(sock, buf1, strlen(pts), );
goto flag1;
end: closesocket(sock); // 关闭监听套接字 WSACleanup(); // 卸载winsock library printf("\n按回车键继续...");
getchar(); // 等待任意按键
}
【Echo】实验 -- 实现 C/C++下TCP, 服务器/客户端 通讯的更多相关文章
- 【Chat】实验 -- 实现 C/C++下TCP, 服务器/客户端 "多人聊天室"
本次实验利用TCP/IP, 语言环境为 C/C++ 利用套接字Socket编程,以及线程处理, 实现Server/CLient 之间多人的聊天系统的基本功能. 结果大致如: 下面贴上代码(参考参考.. ...
- 【Echo】实验 -- 实现 C/C++下UDP, 服务器/客户端 通讯
本次实验利用UDP协议, 语言环境为 C/C++ 利用套接字Socket编程,实现Server/CLient 之间简单的通讯. 结果应为类似所示: 下面贴上代码(参考参考...) Server 部分: ...
- 提升linux下TCP服务器并发连接数(limit)
https://cloud.tencent.com/developer/article/1069900 1.修改用户进程可打开文件数限制 在Linux平台上,无论编写客户端程序还是服务端程序,在进 ...
- 提升linux下tcp服务器并发连接数限制
1.修改用户进程可打开文件数限制 在Linux平台上,无论编写客户端程序还是服务端程序,在进行高并发TCP连接处理时,最高的并发数量都要受到系统对用户单一进程同时可打开文件数量的限制(这是因为系统 ...
- TCP服务器/客户端代码示例
TCP服务器代码: #include <errno.h> #include <string.h> #include <stdlib.h> #include < ...
- windows下TCP服务器和客户端的实现
服务器 1.初始化 WSAStartup(..) 2.创建Socket s = Socket ( .. ) 3.绑定端口 ret = bind ( ... ) 4.监听 ret = ...
- Linux下tcp服务器创建的步骤
创建一个socket,使用函数socket() socket(套接字)实质上提供了进程通信的端点,进程通信之前,双方首先必须建立各自的一个端点,否则没有办法通信.通过socket将IP地址和端口绑定之 ...
- 对Qt下对话服务器客户端的总结(MyTcpServer与MyTcpClient)
在汇文培训老师给讲了这个例子.讲的挺好的 Qt编写聊天服务器与客户端主要用到下面两个类: QTcpSocket --- 处理连接的 QTcpServer --- 处理服务器,对接入进行响应,创建每个链 ...
- socket本地模拟TCP 服务器+客户端(二)
建立两个py文件,分别打开两个cmd界面,即可进行通信.服务器端运用多进程,连续不断的处理从客户端接收到的数据:客户端通过一个list不断给客户端发送数据. (每个连接都必须创建新线程(或进程)来处理 ...
随机推荐
- spring 3.0版本以上jar包使用以及依赖关系
本文转载自:http://blog.csdn.net/huiwenjie168/article/details/8477837 spring.jar是包含有完整发布的单个jar包,spring.jar ...
- (zxing.net)二维码PDF417的简介、实现与解码
一.简介 二维码PDF417是一种堆叠式二维条码.PDF417条码是由美国SYMBOL公司发明的,PDF(Portable Data File)意思是“便携数据文件”.组成条码的每一个条码字符由4个条 ...
- Mustache 使用说明
Mustache 使用说明 最近在升级SinGooCMS到MVC架构.管理前端使用了Mustache模板,把使用心得记录一下! 一.官网http://mustache.github.io/https: ...
- win10下安装配置iis,发布iis
老有朋友不会配置iis跟发布iis,今天整理一下,欢迎参考借鉴 打开控制面板 找到 程序 点击程序 找到启用或关闭windows功能 在windows服务中找到 Internet Informati ...
- php 命令行脚本运行php文件简单演示
众说周知,php在web服务器领域有着很重要的角色,可是它不仅仅在web领域,只是在web领域表现更为优秀! 它基本有三种用途: web服务端脚本的编写 应用程序图形界面(类似windows自带的计算 ...
- django系列6--Ajax05 请求头ContentType, 使用Ajax上传文件
一.请求头ContentType ContentType指的是请求体的编码类型,常见的类型共有三种: 1.application/x-www-form-urlencoded 这应该是最常见的 POST ...
- java中集合
一. List集合: 一次只存储一个元素 1.常用的list集合是ArrayList (1)在创建这个集合的对象时, 需要指定这个集合存储的数据类型! 否则这个集合的数据是不安全的. (2)与数组的 ...
- LCS - Longest Common Substring(spoj1811) (sam(后缀自动机)+LCS)
A string is finite sequence of characters over a non-empty finite set \(\sum\). In this problem, \(\ ...
- json 模块的基本使用学习
内容大纲 1: 为什么要学习json模块 >1:因为网络之间的通信,还有不同语言之间的相互内容沟通,需要用到json 模式进行沟通 >2:写入部分文件用json文件保存, 2:json的序 ...
- 【Quartz】工作原理
本文参考至http://www.cnblogs.com/davidwang456/p/4205237.html和https://blog.csdn.net/guolong1983811/article ...