c++ Socket客户端和服务端示例版本二
客户端
#include <stdio.h>
#include <stdlib.h>
#include <errno.h>
#include <sys/socket.h>
#include <sys/types.h>
#include <netinet/in.h>
#include <string.h>
#include<arpa/inet.h>
#include <error.h>
#include <unistd.h>
#include <arpa/inet.h>
#include <netinet/in.h>
//执行 ./ClientLinux.out 127.0.0.1 8080
int main(int arg, char* args[])
{
for (int i = ; i < ; i++)
{
printf("arg:%s\n",args[i]);
}
if (arg < )
{
printf("arg<3\n");
return - ;
}
int port = atoi(args[]);
//第一步:初始化一个socket实例
int st = socket(AF_INET, SOCK_STREAM, ); //第二步:定义一个IP地址结构并设置值
struct sockaddr_in addr;
//内存初始化,将addr变量指向的内存签n个字节用0进行初始化填充
memset(&addr, , sizeof(addr));
//设置采用的协议为TCP/IP协议
addr.sin_family = AF_INET;
//设置端口号
addr.sin_port = htons(port);
//设置IP地址
addr.sin_addr.s_addr = inet_addr(args[]); //第三步:开始连接服务端
if (connect(st, (struct sockaddr*) & addr, sizeof(addr)) == -)
{
printf("connect fail %s\n", strerror(errno));
return EXIT_FAILURE;
} //第四步:初始化要发送的信息并且通过send函数发送数据
while ()
{
char s[];
memset(s, , sizeof(s));
//read(STDIN_FILENO, s, sizeof(s));
scanf("%s", s);
//strcpy(s, "hello world");
if (send(st, s, strlen(s), ) == -)
{
printf("send fail %s\n", strerror(errno));
return EXIT_FAILURE;
}
//客户端接受服务端消息之前情况缓冲区
memset(s, , sizeof(s));
//客户端接受服务端返回的消息
int rc = recv(st, s, sizeof(s), );
if (rc > )//如果接受服务端消息成功,就打印出来
{
printf("client recv : %s\n", s);
}
else
{
break;
}
} close(st);
getchar();
return EXIT_SUCCESS;
}
服务端
#include <stdio.h>
#include <stdlib.h>
#include <errno.h>
#include <sys/socket.h>
#include <sys/types.h>
#include <netinet/in.h>
#include <string.h>
#include<arpa/inet.h>
#include <error.h>
#include <unistd.h>
#include <arpa/inet.h>
#include <netinet/in.h>
//执行命令 ./ServerLinux.out 8080
int main(int arg, char* args[])
{
for (int i = ; i < ; i++)
{
printf("参数%d:%s", i, args[i]);
}
if (arg<)
{
return -;
}
int port = atoi(args[]);
int st = socket(AF_INET, SOCK_STREAM, ); //setsockopt 设置socket的一个属性,让地址可以重用。
int on = ;
if (setsockopt(st, SOL_SOCKET, SO_REUSEADDR, &on, sizeof(on)) == -)
{
printf("setsockopt failed:%s\n", strerror(errno));
return EXIT_FAILURE;
}
struct sockaddr_in addr;
memset(&addr, , sizeof(addr));
addr.sin_family = AF_INET;
addr.sin_port = htons(port);
//INADDR_ANY表示这个服务器上的所有Ip地址。一台服务器可以有多个ip地址。将socket绑定到这个机器的所有ip地址上
addr.sin_addr.s_addr = htonl(INADDR_ANY); //将ip地址与server程序绑定
if (bind(st, (struct sockaddr*) & addr, sizeof(addr)) == -)
{
printf("bind fail %s\n", strerror(errno));
return EXIT_FAILURE;
}
//server开始监听。 20代表同时有多少个连接过来(20并发)
if (listen(st, ) == -)
{
printf("listen fail %s\n", strerror(errno));
return EXIT_FAILURE;
}
char s[];
int client_st = ;//客户端socket
socklen_t len = ;//
struct sockaddr_in client_addr;//客户端IP
void* p = &client_addr;
int i = ;
for (i = ; i < ; i++)
{
memset(&client_addr, , sizeof(client_addr));
socklen_t len = sizeof(client_addr);
//accept会阻塞,直到有客户端连接过来。accept返回客户端的描述符
client_st = accept(st, (struct sockaddr*) & client_addr, &len);
if (client_st == -)
{
printf("accept fail %s\n", strerror(errno));
return EXIT_FAILURE;
}
//打印客户端的ip地址
printf("accept ip : %s\n", inet_ntoa(client_addr.sin_addr));
memset(s, , sizeof()); ////接受来自客户端的消息
//if (recv(client_st, s, sizeof(s), 0) == -1)
//{
// printf("receive fail %s\n", strerror(errno));
// close(client_st);
// return EXIT_FAILURE;
//}
//printf("内容:%s\n", s); while ()
{
memset(s, , sizeof(s));
//recv是阻塞调用,如果客户端不关闭,那么服务端就会死等
int rc = recv(client_st, s, sizeof(s), );
if (rc > )
{
printf("receive success %s\n", s);
memset(s, , sizeof(s));
//从控制台接受输入的数据
scanf("%s", s);
//服务端向客户端返回消息
send(client_st, s, sizeof(s), );
}
else if (rc == )//如果客户端关闭连接,server端接受时,返回0
{
printf("receive close\n");
break;
}
else
{
printf("receive fail %s\n", strerror(errno));
break;
}
}
close(client_st);//关闭客户端的socket
}
close(st);
getchar();
}
c++ Socket客户端和服务端示例版本二的更多相关文章
- c++ Socket客户端和服务端示例版本三(多线程版本)
客户端 #include <stdio.h> #include <stdlib.h> #include <errno.h> #include <sys/soc ...
- c++ Socket客户端和服务端示例版本一
客户端 #include <stdio.h> #include <stdlib.h> #include <errno.h> #include <sys/soc ...
- c#Socket客户端和服务端的信息发送
这是我制作的界面信息,c# Socket通信的简单使用,刚开始学习,不对的地方请大家指教,目前是可以运行的,之后自己在慢慢添加新的东西.同时了解Tcp协议的三次握手.希望对跟我一样的初学者有所帮助. ...
- socket 客户端和服务端通信
客户端要连接服务器:首先要知道服务器的IP地址.而服务器里有很多的应用程序,每一个应用程序对应一个端口号 所以客户端想要与服务器中的某个应用程序进行通信就必须要知道那个应用程序的所在服务器的IP地址, ...
- java Socket通信,客户端与服务端相互发消息
1.通信过程 网络分为应用层,http.ssh.telnet就是属于这一类,建立在传输层的基础上.其实就是定义了各自的编码解码格式,分层如下: 2.Socket连接 上述通信都要先在传输层有建立连接的 ...
- 基于开源SuperSocket实现客户端和服务端通信项目实战
一.课程介绍 本期带给大家分享的是基于SuperSocket的项目实战,阿笨在实际工作中遇到的真实业务场景,请跟随阿笨的视角去如何实现打通B/S与C/S网络通讯,如果您对本期的<基于开源Supe ...
- swoole 客户端和服务端不断通信
server.php <?php class Chat { const HOST = '0.0.0.0';//ip地址 0.0.0.0代表接受所有ip的访问 const PART = 9501; ...
- socket创建TCP服务端和客户端
看情况选择相对应的套接字*面向连接的传输--tcp协议--可靠的--流式套接字(SOCK_STREAM)*面向无连接的传输--udp协议--不可靠的--数据报套接字(SOCK_DGRAM) 在liun ...
- c++ 网络编程(一)TCP/UDP windows/linux 下入门级socket通信 客户端与服务端交互代码
原文作者:aircraft 原文地址:https://www.cnblogs.com/DOMLX/p/9601511.html c++ 网络编程(一)TCP/UDP 入门级客户端与服务端交互代码 网 ...
随机推荐
- SQL的积累
SQL的积累学习(不常用的经常会忘记,所以以后用到的就会记在下面): --新增字段alter table t_Student add Test varchar(200)--删除字段alter tabl ...
- NOIP2009靶形数独(暴搜)
题目传送门 题目描述 小城和小华都是热爱数学的好学生,最近,他们不约而同地迷上了数独游戏,好胜的他们想用数独来一比高低.但普通的数独对他们来说都过于简单了,于是他们向Z博士请教,Z博士拿出了他最近发明 ...
- android api文档:intent阅读笔记
intent是几大组件之间进行通信的组件.可以包含以下几个部分: component:指明了处理该intent的对象. Action类似于一个函数名,规定了其他部分的对应用法: The action ...
- 【每日一包0007】array-range
[github地址:https://github.com/ABCDdouyae...] array-range 生成一个指定起始位置的固定长度的数组 用法:array-range(start, end ...
- modern php笔记---2.1、特性(命名空间、特性、性状)
modern php笔记---2.1.特性(命名空间.特性.性状) 一.总结 一句话总结: legend2是真的非常好用,资质起码提升5倍,也就是学习效率提升了起码5倍 1.命名空间实质? 从技术层面 ...
- js中的相等
概述 今天学习 jest,看文档的时候发现 jest 用到了 Object.is(),以前没有见过,所以记录下来,供以后开发时参考,相信对其他人也有用. 注意:Object.is的文档在这里 Obje ...
- Vue项目移动端滚动穿透问题
概述 今天在做 Vue 移动端项目的时候遇到了滚动穿透问题,在网上查资料后,选取了我觉得最好的方法,记录下来供以后开发时参考,相信对其他人也有用. 上层无需滚动 如果上层无需滚动的话,直接屏蔽上层的 ...
- P站图片下载工具。
下载 Pixiv 的图片比较麻烦,就做了这么个东西. 主要就是用 HttpWebRequest HttpWebResponse 下载了网页的 html 代码然后截取里面的内容.代码上传到了文件里. p ...
- 测试需要了解的技术之基础篇四__UI自动化测试体系
UI自动化测试体系 1.Andriod 自动化测试:Appium 环境安装与架构介绍.Appium Desktop用例录制.Appium测试用例流程.元素定位方法 IA/AID/XPATH/UISel ...
- lsb-realse
[root@localhost ~]# lsb_release -a -bash: lsb_release: command not found 解决方法:yum install redhat-lsb ...