初试linux下的Socket通信(下)

自己动手写客户端程序

同样是实现上篇的功能,客户端程序不再用telnet,自己写代码实现,服务器端程序也需要修改下

  1. 服务器程序
#include  <stdio.h>
#include <stdlib.h>
#include <unistd.h>
#include <string.h>
#include <errno.h>
#include <sys/socket.h>
#include <arpa/inet.h>

void error(char *msg)
{
    fprintf(stderr, "%s :  %s\n", msg, strerror(errno) );
    exit(1);
}

int open_listener_socket(void)
{
    int s = socket(PF_INET,  SOCK_STREAM, 0); //创建服务器Socket ,  Ipv4协议,面向连接通信,TCP协议
    if (s == -1)
        error("scoket open error");
    return s;
}

void bind_to_port(int socket, int port)
{
    struct sockaddr_in name;  //服务器网络地址结构体
    name.sin_family = PF_INET;
    name.sin_port = (in_port_t)htons(port);          // 服务器端口号
    name.sin_addr.s_addr = htonl(INADDR_ANY);  //服务器地址,允许连接到所有本地连接上

    // 设置socket能重新使用已经绑定过的接口
    int reuse = 1;
    if ( setsockopt(socket, SOL_SOCKET, SO_REUSEADDR, (char *)&reuse, sizeof(int)) == -1)
        error(" cant set the reuse option on the scoket");

    //将服务器socket绑定到网络地址上
    int c = bind(socket, (struct sockaddr*) &name, sizeof(name));
    if (c == -1)
        error("cant bind to socket");
}

int sent_msg_to_client(int socket, char *s)
{
    int result = send(socket, s, strlen(s), 0);
    if (result == -1)
        fprintf(stderr, "%s :  %s\n", "error talking to client", strerror(errno) );
    return result;
}

int main(int argc, char const *argv[])
{
    int server_sockfd;
    int len;

    server_sockfd = open_listener_socket();
    bind_to_port(server_sockfd , 30000);

    // 监听连接请求,监听队列长度为10
    if (listen(server_sockfd , 10) == -1)
        error("cant listen");

    struct sockaddr_storage client_addr;   //client_addr 保存连接客户端的详细信息
    unsigned int address_size = sizeof(client_addr);
    puts("waiting for connection");
    char buf[255];
    //等待客户端连接请求到达
    int client_sockfd = accept(server_sockfd, (struct sockaddr *)&client_addr, &address_size);
    if (client_sockfd == -1)
        error("accept error");
    sent_msg_to_client( client_sockfd, "Welcome to my server\n>");
    while ((len = recv(client_sockfd, buf, sizeof(buf), 0)) > 0)
    {
        buf[len] = ‘\0‘;
        printf("%s\n", buf);
        if (strncasecmp("Who is there?", buf, 12))
            sent_msg_to_client(client_sockfd, "You should say ‘Who is there?‘ !\r\n>");
        else
        {
            sent_msg_to_client(client_sockfd, "Oscar\r\n>");
            while ((len = recv(client_sockfd, buf, sizeof(buf), 0)) > 0)
            {
                buf[len] = ‘\0‘;
                printf("%s\n", buf);
                if (strncasecmp("Oscar who?", buf, 9))
                {
                    sent_msg_to_client(client_sockfd, "You should say ‘Oscar who?‘ !\r\n>");
                    continue;
                }
                else
                {
                    sent_msg_to_client(client_sockfd, "Oscar silly question, you get a silly answer\r\n");
                    break;
                }

            }

        }

    }
    return 0;
}

  1. 客户端程序
#include  <stdio.h>
#include <stdlib.h>
#include <unistd.h>
#include <string.h>
#include <errno.h>
#include <sys/socket.h>
#include <arpa/inet.h>

void error(char *msg)
{
    fprintf(stderr, "%s :  %s\n", msg, strerror(errno) );
    exit(1);
}

int open_listener_socket(void)
{
    int s = socket(AF_INET,  SOCK_STREAM, 0); //创建服务器Socket ,  Ipv4协议,面向连接通信,TCP协议
    if (s == -1)
        error("scoket open error");
    return s;
}

int main(int argc, char *argv[])
{
    int client_sockfd;
    char buf[255];
    int len;
    struct sockaddr_in client_addr; //客户端网络地址结构体

    client_addr.sin_family=PF_INET; //设置为IP通信
    client_addr.sin_addr.s_addr=inet_addr("127.0.0.1");//服务器IP地址
    client_addr.sin_port=htons(30000); //服务器端口号

    /*创建客户端套接字--IPv4协议,面向连接通信,TCP协议*/
    client_sockfd= open_listener_socket();
    /*将套接字绑定到客户端的网络地址上*/

    if(connect(client_sockfd,(struct sockaddr *)&client_addr,sizeof(struct sockaddr)) == -1)
    {
        error("cant connected to server");
    }
    puts("connected to server\n");
    len=recv(client_sockfd,buf,BUFSIZ,0);//接收服务器端信息
            buf[len]=‘\0‘;
    printf("%s",buf); //打印服务器端信息

    while(1)
    {
        //scanf("%s",buf);
        gets(buf);
        if(!strcmp(buf,"quit"))
            break;
        len=send(client_sockfd,buf,strlen(buf),0);

        len=recv(client_sockfd,buf,BUFSIZ,0);
        buf[len]=‘\0‘;
        printf("%s",buf);

    }
    close(client_sockfd);//关闭套接字

         return 0;
}

时间: 2024-10-22 05:03:00

初试linux下的Socket通信(下)的相关文章

Linux - 面向连接的socket通信流程

字符串的IP与32的IP的转换 说明 网络上的IP都是数字加点(192.168.0.1)构成 struct in_addr结构使用32位的IP,如 IP(C0A80001)是192.168.0.1 函数原型 int inet_aton(const char *cp, struct in_addr *inp) 将a.b.c.d的IP转换为32位的IP,存储在 inp指针里面 char *inet_ntoa(struct in_addr in) 将32位IP转换为a.b.c.d的格式 说明 a代表

c++ 网络编程(二)TCP/IP linux 下多进程socket通信 多个客户端与单个服务端交互代码实现回声服务器

原文作者:aircraft 原文链接:https://www.cnblogs.com/DOMLX/p/9612820.html LINUX下: 一.服务端代码 下面用了多个close来关闭文件描述符,可能有的小伙伴会有疑惑....我就说一句,创建进程的时候会把父进程的资源都复制 一份,而你这个子进程只需要保留自己需要处理的资源,其他的自然要关闭掉, 不然父亲一个儿子一个 待会打起来怎么办  嘿嘿 注意了:就像进程间的通信需要属于操作系统的资源管道来进行,套接字也属于操作系统,所以创建新进程也还是

linux下的socket通信小程序分享

最近学习unix网络编程,感觉东西零零碎碎,比较混乱.因此决定整理以下,发一个小博客.一来可以与大家分享以下,二来可以总结提高一下所学的东西.话说:竹子为什么长的高,因为它喜欢总结阿--^_^ 废话不多说了,上代码.小弟半路出家,入行不深,过路大神不喜勿喷阿,嘿嘿--^_^ 程序是一个基于tcp的 C/S .简单回显功能( 声明以下,不要以为注释是英语就说我是在哪里下载的,原因是我运行程序 汉字老显示乱码,就改成蹩脚英语了 ). 首先是一个自己的库 1 #ifndef MYLIB_H 2 #de

Centos 64下实现socket通信

源码: /* File Name: server.c */ #include<stdio.h> #include<stdlib.h> #include<string.h> #include<errno.h> #include<sys/types.h> #include<sys/socket.h> #include<netinet/in.h> //Ineternet address family #include<ar

TCP,UDP协议下的socket通信

TCP通信流程 Server端: 创建套接字:socket( ) 创建sockaddr_in结构体变量,并设置相关参数 将套接字与IP.端口绑定:bind( ) 使套接字处于监听状态,等待Client端发起连接请求:listen( ) 取接收请求,并生成已连接socket描述符:accept( ) 进行网络读写操作:read()/write() .recv()/send() 关闭套接字:close( ) Client端 创建套接字:socket( ) 创建sockaddr_in结构体变量,并设置

Linux C++ TCP Socket通信实例

环境:Linux 语言:C++ 通信方式:TCP 下面用TCP协议编写一个简单的服务器.客户端,其中服务器端一直监听本机的6666号端口.如果收到连接请求,将接收请求并接收客户端发来的消息:客户端与服务器端建立连接并发送一条消息. server.cpp 1 #include<stdio.h> 2 #include<stdlib.h> 3 #include<string.h> 4 #include<errno.h> 5 #include<sys/type

Socket通信——C++server端和Javaclient

一句话来说就是.C++和Java 通过socket进行通信.传输数据.通过发送"字节流"就可以. 字节对于C++和java来说是通用的.可是传输的过程有很多问题须要注意,我为了弄清楚这个过程,查了一些资料,做了一些整理. 不了解C++ socket编程,能够看这篇博客: Linux 下:socket通信(Linux下,C/C++语言):http://blog.csdn.net/giantpoplar/article/details/47657303 Windows下:winsock:h

Socket通信——C++服务器端和Java客户端

一句话来说就是,C++和Java 通过socket进行通信.数据传输,通过发送"字节流"即可. 字节对于C++和java来说是通用的,但是传输的过程有许多问题需要注意,我为了弄清楚这个过程,查了一些资料,做了一些整理. 不了解C++ socket编程,可以看这篇博客: Linux 下:socket通信(Linux下,C/C++语言):http://blog.csdn.net/giantpoplar/article/details/47657303 Windows下:winsock:ht

使用Socket通信实现Silverlight客户端实时数据的获取(模拟GPS数据,地图实时位置)

原文:使用Socket通信实现Silverlight客户端实时数据的获取(模拟GPS数据,地图实时位置) 在上一篇中说到了Silverlight下的Socket通信,在最后的时候说到本篇将会结合地图.下面就来看看本文实现的功能: Silverlight 与服务器利用Socket通讯,实时从服务器获取数据(本文中的数据是地理坐标),由于没有GPS,所以本文在服务器写了一个构造新坐标的函数(本文是一个三角函数),然后利用Timer组件,实时调用,得到新的坐标,并将新的坐标发送给客户端,客户端接收到发