Linux下实现客户端和服务器端的通信
首先,可以将代码复制下来放到U盘里,然后挂载到Linux上
挂载步骤
找到设备->USB->你U盘的名字
挂载成功
访问U盘把代码拷贝到home文件夹下,就可以直接进行编译。
client.c
- #include <stdio.h>
- #include <unistd.h>
- #include <strings.h>
- #include<string.h>
- #include <sys/types.h>
- #include <sys/socket.h>
- #include <stdlib.h>
- #include <netinet/in.h>
- #include <netdb.h>
- #define PORT 1234
- #define MAXDATASIZE 100
- char receiveM[];
- char sendM[];
- int main(int argc, char *argv[])
- {
- int fd, numbytes;
- struct hostent *he;
- struct sockaddr_in server;
- //检查用户输入,如果用户输入不正确,提示用户正确的输入方法
- if (argc !=) { printf("Usage: %s <IP Address>\n",argv[]);
- exit();
- }
- // 通过函数 gethostbyname()获得字符串形式的ip地址,并赋给he
- if ((he=gethostbyname(argv[]))==NULL){
- printf("gethostbyname() error\n");
- exit();
- }
- // 产生套接字fd
- if ((fd=socket(AF_INET, SOCK_STREAM, ))==-){
- printf("socket() error\n");
- exit();
- }
- bzero(&server,sizeof(server));
- server.sin_family = AF_INET;
- server.sin_port = htons(PORT);
- server.sin_addr = *((struct in_addr *)he->h_addr);
- if(connect(fd, (struct sockaddr *)&server,sizeof(struct sockaddr))==-){
- printf("connect() error\n");
- exit();
- }
- // 向服务器发送数据
- printf("send message to server:");
- fgets(sendM,,stdin);
- int send_le;
- send_le=strlen(sendM);
- sendM[send_le-]='\0';
- send(fd,sendM,strlen(sendM),);
- // 从服务器接收数据
- if ((numbytes=recv(fd,receiveM,MAXDATASIZE,)) == -){
- printf("recv() error\n");
- exit();
- }
- printf("receive message from server:%s\n",receiveM);
- close(fd);
- }
server.c
- #include <stdio.h>
- #include <string.h>
- #include <strings.h>
- #include <stdlib.h>
- #include <unistd.h>
- #include <sys/types.h>
- #include <sys/socket.h>
- #include <netinet/in.h>
- #include <arpa/inet.h>
- #include<pthread.h>
- #define PORT 1234
- #define BACKLOG 1
- void *start_routine( void *ptr)
- {
- int fd = *(int *)ptr;
- char buf[];
- int numbytes;
- int i,c=;
- printf("this is a new thread,you got connected\n");
- printf("fd=%d\n",fd);
- if ((numbytes=recv(fd,buf,,)) == -){
- printf("recv() error\n");
- exit();
- }
- char str[numbytes];
- char buffer[numbytes];
- //将收到的字符串反转
- for(c=;c<(numbytes-);c++)
- {
- buffer[c]=buf[c];
- }
- printf("receive message:%s\n",buf);
- printf("numbytes=%d\n",numbytes);
- for(i=;i<numbytes;i++)
- {
- str[i]=buf[numbytes--i];
- }
- printf("server will send:%s\n",str);
- numbytes=send(fd,str,sizeof(str),);
- printf("send numbytes=%d\n",numbytes);
- close(fd);
- }
- int main()
- {
- int listenfd, connectfd;
- struct sockaddr_in server;
- struct sockaddr_in client;
- int sin_size;
- sin_size=sizeof(struct sockaddr_in);
- pthread_t thread; //定义一个线程号
- if ((listenfd = socket(AF_INET, SOCK_STREAM, )) == -)
- {
- perror("Creating socket failed.");
- exit();
- }
- int opt = SO_REUSEADDR;
- setsockopt(listenfd, SOL_SOCKET, SO_REUSEADDR, &opt, sizeof(opt));
- bzero(&server,sizeof(server));
- server.sin_family=AF_INET;
- server.sin_port=htons(PORT);
- server.sin_addr.s_addr = htonl (INADDR_ANY);
- // 绑定
- if (bind(listenfd, (struct sockaddr *)&server, sizeof(struct sockaddr)) == -) {
- perror("Bind error.");
- exit();
- }
- // 监听
- if(listen(listenfd,BACKLOG) == -){ /* calls listen() */
- perror("listen() error\n");
- exit();
- }
- while()
- {
- // accept
- if ((connectfd = accept(listenfd,(struct sockaddr *)&client,&sin_size))==-) {
- perror("accept() error\n");
- exit();
- }
- printf("You got a connection from %s\n",inet_ntoa(client.sin_addr) );
- pthread_create(&thread,NULL,start_routine,(void *)&connectfd);
- }
- close(listenfd);
- }
代码从U盘复制到home后,编译执行
打开三个中端
可以发现用户端和服务器端连接成功,即用户端发送的信息,服务器端可以接收的到。
Linux下实现客户端和服务器端的通信的更多相关文章
- Linux 下 简单客户端服务器通讯模型(TCP)
原文:Linux 下 简单客户端服务器通讯模型(TCP) 服务器端:server.c #include<stdio.h> #include<stdlib.h> #include ...
- Linux下librdkafka客户端的编译运行
Linux下librdkafka客户端的编译运行 librdkafka是一个开源的Kafka客户端C/C++实现,提供了Kafka生产者.消费者接口. 由于项目需要,我要将Kafka生产者接口封装起来 ...
- linux下MongoDB客户端shell基本操作
MongoDB 是一款NoSql数据库,没有固定的模式,即同一个集合中的不同文档结构可以不同,如:第一条记录{name:”xiaoming”},第二条记录:{name:”xiaoli”,age:15} ...
- (转)Linux下 SVN客户端安装
原地址:http://rtxbc.iteye.com/blog/860092 今天有现场程序连svn服务器一直有异常,于是在现场linux下安装svn client来直接测试,看问题原因: 一:安装s ...
- Linux下PHP与普通C程序通信
Linux下的普通C程序之前可以使用FIFO(有名管道来进行进程间通信,因为这个管道以一个文件的形式存在于文件系统上,因此只要能读写这个文件就可以实现进程间通信. 首先使用mkfifo命令有文件系统上 ...
- Linux下onvif客户端获取ipc摄像头 GetServices:获取媒体地址(有的h265摄像头必须要这个接口)
GetServices:获取媒体地址(有些h265的摄像头必须用到这个接口,得到获取能力时没获取到的另一个媒体地址) 鉴权:但是在使用这个接口之前是需要鉴权的.ONVIF协议规定,部分接口需要鉴权,部 ...
- Linux下onvif客户端关于ipc摄像头的搜索
设备搜索:要访问一个IPC摄像头,或者说要调用IPC摄像头提供的WEB服务接口,就要先知道其IP地址,这就是设备发现的过程,或者叫设备搜索的过程.IPC摄像头用的是239.255.255.250(端口 ...
- Linux下onvif客户端获取h265 IPC摄像头的RTSP地址
1. 设备搜索,去获取webserver 的地址 ,目的是在获取能力提供服务地址,demo:https://www.cnblogs.com/croxd/p/10683429.html 2. GetCa ...
- Linux下onvif客户端获取ipc摄像头 GetStreamUri:rtsp地址(h264、h265)
GetStreamUri:rtsp地址 鉴权:但是在使用这个接口之前是需要鉴权的.ONVIF协议规定,部分接口需要鉴权,部分接口不需要鉴权,在调用需要鉴权的接口时不使用鉴权,会导致接口调用失败.实现鉴 ...
随机推荐
- Nmap参考指南中文版
Nmap参考指南中文版 来源: http://www.nmap.com.cn/doc/manual.shtm 译注 该Nmap参考指南中文版由Fei Yang <fyang1024@gmail. ...
- 循环冗余校验(CRC)
冗余码 CRC和海明校验类似,也是有效信息(k位)+校验信息(r位),需要满足N=k+r≤2r-1 生成多项式G(X) 定义:收发双方约定的一个(r+1)位二进制数,发送方利用G(X)对信息多项式做模 ...
- html标签的target属性应用
1. 定义和用法 target 属性规定在何处打开页面上的所有链接. <head> <base target="_blank" /> </head&g ...
- SpringBoot 快速支持国际化i18n
学习目标 快速学会如何在工程中支持国际化语言. 快速查阅 专题阅读:<SpringBoot 布道系列> 源码下载:springboot-locale-i18n — Hey Man,Don' ...
- sd卡无法启动及zc706更改主频后可以进入uboot无法启动kernel的坑
好长的标题 +_+ 1.sd卡无法启动 起因:kernel底下通过dd测试速度,擦写了sd卡,再启动时发现无法启动 于是重新格式化,再将BOOT.bin 相关dtb u-rootfs zImage和u ...
- Center os6.5 mysql
1 # yum -y install mysql-server mysql mysql-dev 2 启动mysql # service mysqld start 3 为root用户配置一个密码 ...
- php 从7.0升级到7.2
下面的方法安装的php是非线程安全的,apache2服务器用不了 1. 添加Ondřej Surý提供的PHP源: sudo apt-get install software-properties-c ...
- python基础:1.位、字节、字的关系
1.位,简称b,或bit,比特,数据存储的最小单位.每个二进制数字0或1就是一个位(bit),网络通信常用bps,bit per second ,每秒传输多少位 2.字节,简称byte, 1byte ...
- 重新调整动态vhdx占用的空间
优化vhd:https://docs.microsoft.com/en-us/powershell/module/hyper-v/optimize-vhd?view=win10-ps 1. 弹出vhd ...
- sql200安装问题
解决方法: 首先把安装目录和C:\Program Files下的Microsoft SQL Server文件夹删了,删除在current_user和local_machine\software\mic ...