C 程序挂在 strcmp 附近

C program hanging near strcmp

我正在 C 中构建一个 client-server socket 模拟 我接受来自客户端的 TCP connection 然后客户端向我的服务器发送消息。我成功收到消息,然后遍历 array of structs 以查找字符串匹配项

struct Mapping
{
  char  key[6];
  char  value[8];
} MapElement;

int main
{
  char buf[BUFSIZE]; /* BUFSIZE 2048 */
  int size = 4;
  struct Mapping serverMap[size];
  initialize_server_map(serverMap); /* This method works, so not displaying in SO */

  /* ... socket stuff (this works as seen from print statements) */

  recvlen = recv(rqst, buf, BUFSIZE, 0);
  printf("The received length is %d\n", recvlen);
  printf("The buf is: %s\n", buf);
  if (recvlen > 0) {
    buf[recvlen] = 0;
    printf("The Server 2 has received a request with key %s\n", buf);
    char* buf_for_token[10];
    strcpy(buf_for_token, buf);
    const char s[2] = " ";
    char *token;
    token = strtok(buf_for_token, s);
    token = strtok(NULL, s);
    int found = 0;
    for(int i = 0; i < sizeof(serverMap) / sizeof(struct Mapping); i++) {
      printf("Token: %sServerMapEntry: %s\n", token, serverMap[i].key);
      printf("Compare: %d\n", strcmp(serverMap[i].key, token));
      if (strcmp(serverMap[i].key, token) == 0) {
        printf("What is wrong?!?! Why is this not printing?!\n");
        found = 1;
        strcpy(post, "POST ");
        strcat(post, serverMap[i].value);
        if (send(rqst, post, strlen(post), 0) < 0) {
          perror("sendto");
        }
        break;
      }
    }
  }
}

我的输出是:

The received length is 9
The buf is: GET key05
The Server 2 has received a request with key GET key05
Token: key05ServerMapEntry: key05
Compare: 0

我不明白为什么下一个打印语句不打印。我的程序永远挂起。 :(

这里有一个错误:

char* buf_for_token[10];
strcpy(buf_for_token, buf);

你是如何设法编译这个程序的? buf_for_token是指向char的指针数组,应该只是char的数组,并且要足够大:

char buf_for_token[BUFSIZE];
strcpy(buf_for_token, buf);

此缓冲区应与接收缓冲区一样大,并且如评论中所述,您应将小于其大小的 1 传递给 recv,以便为'[=19=]'最后你强行:

recvlen = recv(rqst, buf, sizeof(buf) - 1, 0);

for循环中,使用size代替sizeof(serverMap) / sizeof(struct Mapping),或者sizeof(serverMap) / sizeof(*serverMap)

至于为什么 printf("What is wrong?!?! Why is this not printing?!\n"); 没有输出任何东西,请在 printf() 之后尝试 fflush(stdout); 以确保它不仅仅是一个缓冲问题。

或者也可能是您没有发布确切的代码...post 未定义,并且函数原型缺少一些正文部分:

int main
{

最后,如果您的套接字是 TCP,请注意客户端发送的数据可能会以不同大小的块(较小或较大)被服务器接收。唯一的保证是字节流的顺序。您不应该依赖这样一个事实,即大多数时候您会收到一条完整的线路。网络拥塞或其他超出您控制范围的情况可能会导致数据包被分割并以小块的形式接收或组合成包含多行的大块......要处理服务器中的这种潜在情况,您应该缓冲数据并一次处理一行.

这一行:
char* buf_for_token[10];
说:创建一个包含 10 个元素的数组,指针指向 char
我相信你需要那个:
char buf_for_token[10];