如何初始化缓冲区

how to initialize a buffer

这是我的 server/client 套接字代码。 我的缓冲区有问题,当客户端从作为缓冲区的服务器接收消息时(我将其初始化为“12”),输出显示如下:

[+]Client Socket is created.
[+]Connected to Server.
Temp : 
  12121212121212121212121212121212121212121212121212121212121212121212121212121212 
  12121212121212�L��Q� 

服务器:

#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <unistd.h>
#include <sys/socket.h>
#include <sys/types.h>
#include <netinet/in.h>
#include <arpa/inet.h>

#define PORT 4444

int main(){

int sockfd, ret;
 struct sockaddr_in serverAddr;

int clientSocket;
struct sockaddr_in newAddr;

socklen_t addr_size;

char buffer[1024];
    char Temp[4]= "12";
pid_t childpid;

sockfd = socket(AF_INET, SOCK_STREAM, 0);
if(sockfd < 0){
    printf("[-]Error in connection.\n");
    exit(1);
}
printf("[+]Server Socket is created.\n");

memset(&serverAddr, '[=11=]', sizeof(serverAddr));
serverAddr.sin_family = AF_INET;
serverAddr.sin_port = htons(PORT);
serverAddr.sin_addr.s_addr = inet_addr("127.0.0.1");

ret = bind(sockfd, (struct sockaddr*)&serverAddr, sizeof(serverAddr));
if(ret < 0){
    printf("[-]Error in binding.\n");
    exit(1);
}
printf("[+]Bind to port %d\n", 4444);

if(listen(sockfd, 10) == 0){
    printf("[+]Listening....\n");
}else{
    printf("[-]Error in binding.\n");
}


while(1){
    clientSocket = accept(sockfd, (struct sockaddr*)&newAddr, &addr_size);
    if(clientSocket < 0){
        exit(1);
    }
    printf("Connection accepted from %s:%d\n", inet_ntoa(newAddr.sin_addr), 
   ntohs(newAddr.sin_port));

    if((childpid = fork()) == 0){
        close(sockfd);

        while(1){



        send(clientSocket, Temp, strlen(Temp), 0);
                bzero(buffer, sizeof(buffer));
            if(strcmp(Temp, ":exit") == 0){
                printf("Disconnected from %s:%d\n", 
 inet_ntoa(newAddr.sin_addr), ntohs(newAddr.sin_port));
                break;
        }
    }

 }



}
return 0;
}

客户:

#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <unistd.h>
#include <sys/socket.h>
#include <sys/types.h>
#include <netinet/in.h>
#include <arpa/inet.h>

#define PORT 4444

int main(){

int clientSocket, ret;
struct sockaddr_in serverAddr;
char buffer[1024];
    char Temp[4];

clientSocket = socket(AF_INET, SOCK_STREAM, 0);
if(clientSocket < 0){
    printf("[-]Error in connection.\n");
    exit(1);
}
printf("[+]Client Socket is created.\n");

memset(&serverAddr, '[=12=]', sizeof(serverAddr));
serverAddr.sin_family = AF_INET;
serverAddr.sin_port = htons(PORT);
serverAddr.sin_addr.s_addr = inet_addr("127.0.0.1");

ret = connect(clientSocket, (struct sockaddr*)&serverAddr, 
sizeof(serverAddr));
if(ret < 0){
    printf("[-]Error in connection.\n");
    exit(1);
}
printf("[+]Connected to Server.\n");
   bzero(buffer,512);

   int words = 0;
    char c;

while(1){


             recv(clientSocket, Temp, 1024, 0);
    if(recv(clientSocket, Temp, 1024, 0) < 0){
        printf("[-]Error in receiving data.\n");
    }
           printf("Temp : %s \n",Temp);
       if(strcmp(Temp, ":exit") == 0){
        close(clientSocket);
        printf("[-]Disconnected from server.\n");

    } exit(1);
}



return 0;
}

拜托,谁能告诉我如何解决这个问题,我们将不胜感激。

我发现您的客户端代码有几个问题:

char Temp[4];
...
recv(clientSocket, Temp, 1024, 0);

虽然只为 Temp 分配了 4 个字节,但您在这里最多将 1024 个字节读入 Temp。如果您读取超过 4 个字节,则其他数据结构将被读取的数据填充,即典型的缓冲区溢出。

printf("Temp : %s \n",Temp);

在这里您假设 Temp 是一个 [=15=] 终止的字符串,但事实并非如此。因此,它将打印出从 &Temp 位置开始的数据,直到它会在某处找到的 [=15=] 字节(根据您的输出,在 Temp 之外)。

if(strcmp(Temp, ":exit") == 0){

尽管 Temp 只有 4 个字节,但此语句假设至少有 6 个字节(5 个字节的字符串和 [=15=] 用于字符串结束标记)。

服务器代码也有类似的问题。同样奇怪的是,您的 buffer 变量已初始化但从未使用过。我的猜测是您最初想使用它而不是 Temp 来发送和接收。