【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不断给客户端发送数据. (每个连接都必须创建新线程(或进程)来处理 ...
随机推荐
- 在一般处理程序清理cookie
清理cookie在ashx里面很奇怪,因为直接设置过期时间并不能成功,cookie还是会存在.所以需要添加一个同名的Cookie设置过期时间覆盖 HttpCookie cookie = null; / ...
- ASP.NET MVC学习笔记(二)登陆验证
书上的验证时在配置文件中直接声明用户名和密码,想改成从数据验证账号和密码,搞了一下午都没高出来,不断的调试,发现 var table = userInfo.Tables.FirstOrDefault( ...
- C#多线程编程系列(一)- 简介
目录 系列大纲 一.前言 二.目录结构 四.章节结构 五.相关链接 系列大纲 目前只整理到第二章,线程同步,笔者后面会慢慢更新,争取能把这本书中精华的知识都分享出来. C#多线程编程系列(一)- 简介 ...
- Javascript 535种方式!!!实现页面重载
原文地址: http://www.phpied.com/files/location-location/location-location.html 完全出于好玩,竟然有人整理了500多种方法来实现刷 ...
- iOS 错误 undefined symbols for architecture i386
undefined symbols for architecture i386 这个错误困扰了我几个小时. 网上很多问这个问题的,回答基本上都是说在 target 里面去的 armv64 什么什么的. ...
- Java50道经典习题-程序7 处理字符串
题目:输入一行字符,分别统计出其中英文字母.空格.数字和其它字符的个数.分析:利用while语句,条件为输入的字符不为'\n'. import java.util.*; public class Pr ...
- SVN教程 -- 基于自己学习记录
SVN教程 -- 基于自己学习记录 1. 概述 a. 什么是SVN? Apache Subversion 通常被缩写成 SVN,是一个开放源代码的版本控制系统.相较于 git ,svn 是集中式版本控 ...
- 洛谷P5284 [十二省联考2019]字符串问题(SAM+倍增+最长路)
题面 传送门 题解 首先,我们把串反过来,那么前缀就变成后缀,建一个\(SAM\).我们发现一个节点的后缀是它的所有祖先 那么我们是不是直接按着\(parent\)树建边就可以了呢? 显然不是.我们假 ...
- API接口文档范例
- Python数据分析之文本处理词频统计
1.项目背景: 原本计划着爬某房产网站的数据做点分析, 结果数据太烂了,链家网的数据干净点, 但都是新开楼盘,没有时间维度,分析意义不大. 学习的步伐不能ting,自然语言处理还的go on 2.分析 ...