我正在编写一个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/