client  and  server Demo of socket.

client send data to server.

server send data to client.

// this is client

#include <sys/socket.h>
#include <netinet/in.h>
#include <arpa/inet.h>
#include <assert.h>
#include <stdio.h>
#include <unistd.h>
#include <stdlib.h>
#include <errno.h>
#include <string.h> #define BUFF_SIZE 1024 int main(int argc, char* argv[])
{
if(argc<=)
{
printf("usage:%s ip_address port_number \r\n", basename(argv[]));
return ;
} char* ip = argv[];
int port = atoi(argv[]); struct sockaddr_in address;
bzero(&address, sizeof(address));
address.sin_family = AF_INET;
address.sin_port = htons(port);
inet_pton(AF_INET,ip, &address.sin_addr); int sockfd = socket(PF_INET, SOCK_STREAM, );
assert(sockfd>=); struct sockaddr_in client; int connfd = connect(sockfd, (struct sockaddr*)&address, sizeof(address));
if(connfd < )
{
printf("errno is : %d...connection failed.\r\n", errno );
}
else
{ printf("client:----send-----start\r\n");
char data1[] = "C2S:hello server..";
char data2[] = "C2S:I am client.";
char data3[] = "C2S:centos6 system.Bye-Bye";
send(sockfd, data1, strlen(data1)+, );
sleep();
send(sockfd, data2, strlen(data2)+, );
sleep();
send(sockfd, data3, strlen(data3)+, );
sleep();
printf("client:----send-----finish\r\n"); printf("client:----recv-----start\r\n");
char buffer[BUFF_SIZE];
memset(buffer, '\0', sizeof(buffer));
int ret = recv(sockfd,buffer,sizeof(buffer)-,);
printf("get %d bytes. data:[%s]\r\n", ret, buffer); memset(buffer, '\0', sizeof(buffer));
ret = recv(sockfd,buffer,sizeof(buffer)-,);
printf("get %d bytes. data:[%s]\r\n", ret, buffer); memset(buffer, '\0', sizeof(buffer));
ret = recv(sockfd,buffer,sizeof(buffer)-,);
printf("get %d bytes. data:[%s]\r\n", ret, buffer);
printf("client:----recv-----finish\r\n"); //========================================== buffer[BUFF_SIZE];
memset(buffer, '\0', sizeof(buffer));
ret = recv(sockfd,buffer,sizeof(buffer)-,);
printf("get %d bytes. data:[%s]\r\n", ret, buffer); memset(buffer, '\0', sizeof(buffer));
ret = recv(sockfd,buffer,sizeof(buffer)-,);
printf("get %d bytes. data:[%s]\r\n", ret, buffer); memset(buffer, '\0', sizeof(buffer));
ret = recv(sockfd,buffer,sizeof(buffer)-,);
printf("get %d bytes. data:[%s]\r\n", ret, buffer); close(connfd);
} printf("-----connect closed----\r\n"); close(sockfd); return ;
}

this is  server:

#include <sys/socket.h>
#include <netinet/in.h>
#include <arpa/inet.h>
#include <assert.h>
#include <stdio.h>
#include <unistd.h>
#include <stdlib.h>
#include <errno.h>
#include <string.h> #define BUFF_SIZE 1024 int main(int argc, char* argv[])
{
if(argc<=)
{
printf("usage:%s ip_address port_number \r\n", basename(argv[]));
return ;
} char* ip = argv[];
int port = atoi(argv[]); struct sockaddr_in address;
bzero(&address, sizeof(address));
address.sin_family = AF_INET;
address.sin_port = htons(port);
inet_pton(AF_INET,ip, &address.sin_addr); int sockfd = socket(PF_INET, SOCK_STREAM, );
assert(sockfd>=); int ret = bind(sockfd,(struct sockaddr*)&address, sizeof(address));
assert(ret!=-); ret = listen(sockfd,);
assert(ret!=-); struct sockaddr_in client;
socklen_t client_addlength = sizeof(client);
int connfd = accept(sockfd, (struct sockaddr*)&client, &client_addlength);
if(connfd < )
{
printf("errno is : %d\r\n", errno );
}
else
{
printf("server:----recv-----start\r\n");
char buffer[BUFF_SIZE];
memset(buffer, '\0', sizeof(buffer));
int ret = recv(connfd,buffer,sizeof(buffer)-,);
printf("get %d bytes. data:[%s]\r\n", ret, buffer); memset(buffer, '\0', sizeof(buffer));
ret = recv(connfd,buffer,sizeof(buffer)-,);
printf("get %d bytes. data:[%s]\r\n", ret, buffer); memset(buffer, '\0', sizeof(buffer));
ret = recv(connfd,buffer,sizeof(buffer)-,);
printf("get %d bytes. data:[%s]\r\n", ret, buffer);
printf("server:----recv-----finish\r\n");
sleep(); printf("server:----send-----start\r\n");
char data1[] = "S2C:hello client..";
char data2[] = "S2C:I am server.";
char data3[] = "S2C:centos7 system.Bye-Bye";
send(connfd, data1, strlen(data1)+, ); sleep();
send(connfd, data2, strlen(data2)+, );
sleep();
send(connfd, data3, strlen(data3)+, );
sleep();
printf("server:----send-----finish\r\n"); //======================================== close(STDOUT_FILENO);
dup(connfd); //N messages , once recv.
printf("S2C:==dup==I am server.centos7.");
printf("S2C:==dup==Hello client...");
printf("S2C:==dup==bye-bye."); close(connfd);
} printf("server----------connection closed--------"); close(sockfd); return ;
}

Linux socket program Demo1(client & server)的更多相关文章

  1. AndroidAsync :异步Socket,http(client+server),websocket和socket.io的Android类库

    AndroidAsync是一个用于Android应用的异步Socket,http(client+server),websocket和socket.io的类库.基于NIO,没有线程.它使用java.ni ...

  2. Linux SocketCan client server demo hacking

    /*********************************************************************** * Linux SocketCan client se ...

  3. Client/Server 模型 与socket

    Client/Server 模型  Sockets 是以 Client 和 Server 交互通信方式来使用的.典型的系统配置是把 Server 放在一台机器中,而把 Client 放在另一台机器中, ...

  4. 深入浅出 Redis client/server交互流程

    综述 最近笔者阅读并研究redis源码,在redis客户端与服务器端交互这个内容点上,需要参考网上一些文章,但是遗憾的是发现大部分文章都断断续续的非系统性的,不能给读者此交互流程的整体把握.所以这里我 ...

  5. Network client/server

    <Beginning Linux Programming_4th>  chapter 15 Sockets 1  A simple local client/server 1)  clie ...

  6. linux socket高性能服务器处理框架

    这个博客很多东西 http://blog.csdn.net/luozhonghua2014/article/details/37041765   思考一种高性能的服务器处理框架 1.首先需要一个内存池 ...

  7. Linux socket编程 DNS查询IP地址

    本来是一次计算机网络的实验,但是还没有完全写好,DNS的响应请求报文的冗余信息太多了,不只有IP地址.所以这次的实验主要就是解析DNS报文.同时也需要正确的填充请求报文.如果代码有什么bug,欢迎指正 ...

  8. [Python]再学 socket 之非阻塞 Server

    再学 socket 之非阻塞 Server 本文是基于 python2.7 实现,运行于 Mac 系统下 本篇文章是上一篇初探 socket 的续集, 上一篇文章介绍了:如何建立起一个基本的 sock ...

  9. Linux Socket 编程简介

    在 TCP/IP 协议中,"IP地址 + TCP或UDP端口号" 可以唯一标识网络通讯中的一个进程,"IP地址+端口号" 就称为 socket.本文以一个简单的 ...

随机推荐

  1. 分布式SQL数据库中部分索引的好处

    在优锐课的java学习分享中,探讨了分布式SQL数据库中部分索引的优势,并探讨了性能测试,结果等. 如果使用局部索引而不是常规索引,则在可为空的列上(其中只有一小部分行的该列不具有空值),然后可以大大 ...

  2. PHP TP框架自定义打印函数P

    效果如下,有个灰色背景,也不一定是灰色可以改 代码: //传递数据以易于阅读的样式格式化后输出function p($data){ // 定义样式 $str='<pre style=" ...

  3. 【CF241E】Flights(差分约束)

    [CF241E]Flights(差分约束) 题面 CF 有\(n\)个点\(m\)条边,要求给每条边赋一个\(1\)或\(2\)的边权,判断能否使得每一条\(1\)到\(n\)的路径的权值和都相等,如 ...

  4. CSAPP lab3 bufbomb-缓冲区溢出攻击实验(下)bang boom kaboom

    CSAPP lab3 bufbomb-缓冲区溢出攻击实验(上)smoke fizz CSAPP lab3 bufbomb-缓冲区溢出攻击实验(下)bang boom kaboom 栈结构镇楼 这里先给 ...

  5. Docker第二弹之常用命令

    Docker的常用命令 底层原理 Docker是如何工作的 Docker是一个Client-Server结构的系统,Docker守护进程运行在主机上, 然后通过Socket连接从客户端访问,守护进程从 ...

  6. Serlvet、JSP和JSTL的联系

    没有无缘无故的爱和恨,没有无缘无故的编程 前言: 想这世间,没有无缘无故的爱,也没有无缘无故的恨,一切都有有原因的,我想编程亦是如此,技术时常更新,程序员时常学习,随着时间的推移,程序员发际线的增高, ...

  7. MySQL EXPLAIN 语句

    对于 MySQL 在执行时来说,EXPLAIN 功能上与 DESCRIBE 一样.实际运用中,后者多用来获取表的信息,而前者多用于展示 MySQL 会如何执行 SQL 语句(Obtaining Exe ...

  8. 初学Python常见异常错误,总有一处你会遇到!

    初学Python常见错误 忘记写冒号 误用= 错误 缩紧 变量没有定义 中英文输入法导致的错误 不同数据类型的拼接 索引位置问题 使用字典中不存在的键 忘了括号 漏传参数 缺失依赖库 使用了pytho ...

  9. PlayJava Day011

    今日所学: /* 2019.08.19开始学习,此为补档. */ Java异常处理 1.异常的概念:程序运行过程中发生的问题,从而引发了中断. 2.捕获和处理异常:Java中,用try ... cat ...

  10. SpringMVC学习笔记一(请求流程和配置,启动项目)

    springmvc请求流程: 1.用户发送请求至前端控制器DispatcherServlet 2.DispatcherServlet收到请求调用HandlerMapping处理器映射器. 3.处理器映 ...