码迷,mamicode.com
首页 > 编程语言 > 详细

c++ Socket客户端和服务端示例版本二

时间:2019-11-02 18:22:31      阅读:82      评论:0      收藏:0      [点我收藏+]

标签:use   并且   errno   参数   string   failure   net   bsp   accept   

客户端

#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 = 0; i < 3; i++)
    {
        printf("arg:%s\n",args[i]);
    }
    if (arg < 3)
    {
        printf("arg<3\n");
        return - 1;
    }
    int port = atoi(args[2]);
    //第一步:初始化一个socket实例
    int st = socket(AF_INET, SOCK_STREAM, 0);

    //第二步:定义一个IP地址结构并设置值
    struct sockaddr_in addr;
    //内存初始化,将addr变量指向的内存签n个字节用0进行初始化填充
    memset(&addr, 0, sizeof(addr));
    //设置采用的协议为TCP/IP协议
    addr.sin_family = AF_INET;
    //设置端口号
    addr.sin_port = htons(port);
    //设置IP地址
    addr.sin_addr.s_addr = inet_addr(args[1]);

    //第三步:开始连接服务端
    if (connect(st, (struct sockaddr*) & addr, sizeof(addr)) == -1)
    {
        printf("connect fail %s\n", strerror(errno));
        return EXIT_FAILURE;
    }

    //第四步:初始化要发送的信息并且通过send函数发送数据
    while (1)
    {
        char s[1024];
        memset(s, 0, sizeof(s));
        //read(STDIN_FILENO, s, sizeof(s));
        scanf("%s", s);
        //strcpy(s, "hello world");
        if (send(st, s, strlen(s), 0) == -1)
        {
            printf("send fail %s\n", strerror(errno));
            return EXIT_FAILURE;
        }
        //客户端接受服务端消息之前情况缓冲区
        memset(s, 0, sizeof(s));
        //客户端接受服务端返回的消息
        int rc = recv(st, s, sizeof(s), 0);
        if (rc > 0)//如果接受服务端消息成功,就打印出来
        {
            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 = 0; i < 2; i++)
    {
        printf("参数%d:%s", i, args[i]);
    }
    if (arg<2)
    {
        return -1;
    }
    int port = atoi(args[1]);
    int st = socket(AF_INET, SOCK_STREAM, 0);

    //setsockopt 设置socket的一个属性,让地址可以重用。
    int on = 0;
    if (setsockopt(st, SOL_SOCKET, SO_REUSEADDR, &on, sizeof(on)) == -1)
    {
        printf("setsockopt failed:%s\n", strerror(errno));
        return EXIT_FAILURE;
    }
    struct sockaddr_in addr;
    memset(&addr, 0, 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)) == -1)
    {
        printf("bind fail %s\n", strerror(errno));
        return EXIT_FAILURE;
    }
    //server开始监听。 20代表同时有多少个连接过来(20并发)
    if (listen(st, 20) == -1)
    {
        printf("listen fail %s\n", strerror(errno));
        return EXIT_FAILURE;
    }
    char s[1024];
    int client_st = 0;//客户端socket
    socklen_t len = 0;//
    struct sockaddr_in client_addr;//客户端IP
    void* p = &client_addr;
    int i = 0;
    for (i = 0; i < 50; i++)
    {
        memset(&client_addr, 0, sizeof(client_addr));
        socklen_t len = sizeof(client_addr);
        //accept会阻塞,直到有客户端连接过来。accept返回客户端的描述符
        client_st = accept(st, (struct sockaddr*) & client_addr, &len);
        if (client_st == -1)
        {
            printf("accept fail %s\n", strerror(errno));
            return EXIT_FAILURE;
        }
        //打印客户端的ip地址
        printf("accept ip : %s\n", inet_ntoa(client_addr.sin_addr));
        memset(s, 0, sizeof(1024));


        ////接受来自客户端的消息
        //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 (1)
        {
            memset(s, 0, sizeof(s));
            //recv是阻塞调用,如果客户端不关闭,那么服务端就会死等
            int rc = recv(client_st, s, sizeof(s), 0);
            if (rc > 0)
            {
                printf("receive success %s\n", s);
                memset(s, 0, sizeof(s));
                //从控制台接受输入的数据
                scanf("%s", s);
                //服务端向客户端返回消息
                send(client_st, s, sizeof(s), 0);
            }
            else if (rc == 0)//如果客户端关闭连接,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客户端和服务端示例版本二

标签:use   并且   errno   参数   string   failure   net   bsp   accept   

原文地址:https://www.cnblogs.com/caoruipeng/p/11782982.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!