0

我需要向客户端发送消息,然后客户端必须使用选项进行响应。我一直到客户端和服务器连接,但两个程序都以“分段错误”结束。有谁知道这个错误是什么意思?有人可以就如何创建使客户端和服务器交互的代码给出一个想法。在接收到客户端选择的选项后,服务器必须对其进行分析并再次向客户端发送结果。

我的代码是:

服务器

    int
main(int argc, char **argv)
{
    int                 listenfd, connfd;
    socklen_t           len;
    struct sockaddr_in  servaddr, cliaddr;
    char                buff[MAXLINE];
    time_t              ticks;
    char                message[MAXLINE]="This is the server";
    char                temp_scale[2];
    char                recvdata[MAXLINE + 1];

    listenfd = Socket(AF_INET, SOCK_STREAM, 0);
    bzero(&servaddr, sizeof(servaddr));
    servaddr.sin_family      = AF_INET;
    servaddr.sin_addr.s_addr = htonl(INADDR_ANY);/*----------------------------------------------------*/
    servaddr.sin_port        = htons(5555); 

    Bind(listenfd, (SA *) &servaddr, sizeof(servaddr));
    Listen(listenfd, LISTENQ);

    for ( ; ; )
    {
        len = sizeof(cliaddr);
        connfd = Accept(listenfd, (SA *) &cliaddr, &len);

        printf("Connection from %s, port %d\n",
               Inet_ntop(AF_INET, &cliaddr.sin_addr, buff, sizeof(buff)),
               ntohs(cliaddr.sin_port));


        snprintf(message, sizeof(message), "%s\r\n");
            Writen(connfd, message, strlen(message));
            while ( (n = read(connfd, recvdata, MAXLINE)) > 0)
            {
             recvdata[n] = 0;   /* null terminate*/
             if (fputs(recvdata, stdout) == EOF)
                 err_sys("fputs error");
            }
             if (n < 0)
          err_sys("read error");

           Close(connfd);
    }
}

客户

int
main(int argc, char **argv)
{
    int                 sockfd, rd;
    socklen_t           len;
    char                recvline[MAXLINE + 1];
    struct sockaddr_in  servaddr, cliaddr;
    char  scale[2];

    /*if (argc != 2)
        err_quit("usage: a.out <IPaddress>");*/

    if ( (sockfd = socket(AF_INET, SOCK_STREAM, 0)) < 0)
        err_sys("socket error");

    bzero(&servaddr, sizeof(servaddr));
    servaddr.sin_family = AF_INET;
    servaddr.sin_port   = htons(atoi(argv[2])); /*port passed through command line*/
    if (inet_pton(AF_INET, argv[1], &servaddr.sin_addr) <= 0) /*The client translates the server address, passed on the command line*/
        err_quit("inet_pton error for %s", argv[1]);


    if (connect(sockfd, (SA *) &servaddr, sizeof(servaddr)) < 0)
        err_sys("connect error");

    len = sizeof(cliaddr);
    Getsockname(sockfd, (SA *) &cliaddr, &len);
    printf("Local Address is: %s\n",
           Sock_ntop((SA *) &cliaddr, sizeof(cliaddr))); 

    printf("Iniciando read...\n");
    while ( (rd = read(sockfd, recvline, MAXLINE)) > 0)
    {
        recvline[rd] = 0;   /* null terminate*/
        if (fputs(recvline, stdout) == EOF)
            err_sys("fputs error");
    }
    if (rd < 0)
     err_sys("read error");

    printf("Enter option 'A' or 'B'");
    send_scale(sockfd);

    exit(0);
}

谢谢

4

3 回答 3

2

在调试器中运行您的代码(例如gdb ./a.out)并立即找出答案。

于 2013-03-22T07:54:53.617 回答
2

您的服务器可能因此出现故障:

snprintf(message, sizeof(message), "%s\r\n"); // <== no parameters

这是完全错误的。该snprintf()调用有一个格式说明符,它需要一个char *以空字符结尾的字符串,而您完全没有传递它。因此,它从堆栈中抓取一个随机值,将其视为一个指针,并取消引用它以尝试完成格式化的请求。

在不知道您正在使用的 API 的详细信息的情况下(仅从名称上看,它显然不是标准的 BSD 套接字),没有什么可做的了。

于 2013-03-22T08:10:51.737 回答
1

我不知道它是否有帮助,但在 C 中,当您打印您的回复时,字符串的空终止符是 '\0':

recvdata[n] = 0;   /* null terminate ----> this must be '\0'*/
if (fputs(recvdata, stdout) == EOF)
err_sys("fputs error");

你用“0”填充它,所以当 fputs 解析你的字符串以打印它时,它可能会导致你出现段错误。

希望能帮助到你!

于 2013-07-08T15:11:52.737 回答