我正在编写一个web服务器,在该服务器中,我通过WinSock套接字从客户机接收数据,并将数据解析为多个部分。然后,根据找到的方法和请求的资源,我想构建一个新的包,并将其发送回客户端。
我有这个函数,用来构建包,将nack发送到客户端:(BUFFER_SIZE=2048

char* build_packet(char *ver, char *code, char *content, long length, long *p_length)
{

    char *packet = (char *)malloc(BUFFER_SIZE);
    char *len_str = malloc(BUFF_64);
    _itoa(length, len_str, 10);
    char *content_len = "Content-length: ";
    char *content_type = "Content-Type: ";
    long len = strlen(ver) + 1;
    len += strlen(code) + strlen(HTTP_DELIM);
    len += strlen(content_len) + strlen(len_str) + strlen(HTTP_DELIM);
    len += strlen(content_type) + strlen(HTTP_HTML_TYPE_TEXT) +strlen(HTTP_DELIM);
    len += strlen(content);
    *p_length = len;


// This is where problems start...

// ##############################################################

    strncat(ver, packet, BUFFER_SIZE - 1); // Trouble starts here
    strncat(" ", packet, BUFFER_SIZE - 1);
    strncat(code, packet, BUFFER_SIZE - 1);
    strncat(HTTP_DELIM, packet, BUFFER_SIZE - 1);
    strncat(content_len, packet, BUFFER_SIZE - 1);
    strncat(len_str, packet, BUFFER_SIZE - 1);
    strncat(HTTP_DELIM, packet, BUFFER_SIZE - 1);
    strncat(content_type, packet, BUFFER_SIZE - 1);
    strncat(HTTP_HTML_TYPE_TEXT, packet, BUFFER_SIZE - 1);
    strncat(HTTP_DELIM, packet, BUFFER_SIZE - 1);
    strncat(content, packet, BUFFER_SIZE - 1);

    return packet;

}

(当然,我应该(而且我会)向strncat添加验证,以便它最终发送所有数据)
我的问题是:为什么第一个strncat调用不起作用并引发访问冲突错误?我做错什么了?

最佳答案

你把strncat的参数弄混了。第一个参数应该是目标缓冲区。

strncat(ver, packet, BUFFER_SIZE - 1); // Trouble starts here
strncat(" ", packet, BUFFER_SIZE - 1);
...

您可以将来自packet的相同随机(而不是以nul结尾)数据添加到不同大小的各种其他缓冲区中。
这应该是
strncat(packet, ver, BUFFER_SIZE - 1); // Trouble starts here
strncat(packet, " ", BUFFER_SIZE - 1);
...

还应首先初始化packet
packet[0] = 0;
strncat(packet, ver, BUFFER_SIZE - 1);
strncat(packet, " ", BUFFER_SIZE - 1);
...

关于c - C strncat无法正常工作并引发访问冲突,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/41676391/

10-12 02:57