c - Valgrind错误: "Invalid read of size 1" due to strstr() with C

标签 c valgrind strstr null-terminated

Valgrind 输出:

GET /cs3157/tng/index.html
==760== Invalid read of size 1
==760==    at 0x4C2E7D4: strstr (in /usr/lib/valgrind/vgpreload_memcheck-amd64-linux.so)
==760==    by 0x400E67: HandleTCPClient (http-server.c:101)
==760==    by 0x400D42: main (http-server.c:75)
==760==  Address 0x0 is not stack'd, malloc'd or (recently) free'd

相关代码:

FILE *input = fdopen(clntSocket, "r");      //socket wrapped with FILE * 
if (input == NULL)
{
    perror("fdopen failed");
    fclose(input);
    return;
}
char request_buffer[100];
char out_buf[BUF_SIZE];
int len, res;

while( fgets(request_buffer, sizeof(request_buffer),input) != NULL)
{
    request_buffer[sizeof(request_buffer)-1] = '\0';   //null terminates buffer
    char *request = request_buffer;
    char *token_separators = "\t \r\n"; // tab, space, new line
    char *method = strtok(request, token_separators);
    char *requestURI = strtok(NULL, token_separators);
    char *httpVersion = strtok(NULL, token_separators);

    if( strstr(method,"GET") != NULL )
    {
            if( requestURI[strlen(requestURI)] == '/' ) 
                    requestURI = strcat(requestURI,"index.html");
            printf("%s %s\n", method, requestURI);

    } 
    memset(request_buffer,'\0',sizeof(request_buffer) );
}

fclose(input);      //close the socket by closing the FILE * wrapper

我读到此错误通常是由于未能以 null 终止字符串而引起的。我认为 fgets() 之后的第一行可以防止出现问题。我猜我忽略了一些东西。我感谢任何帮助。

编辑:程序因段错误而崩溃。

最佳答案

听起来(来自 Valgrind 的报告)好像 methodNULL 。您应该使用调试器单步执行此代码,以验证标记化是否按预期工作。

此外,您应该将所有这些指针声明为 const char *因为它们不打算被写入。这当然是一个小问题,但我尝试鼓励使用 const只要有可能。 :)

关于c - Valgrind错误: "Invalid read of size 1" due to strstr() with C,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13601548/

相关文章:

c - sscanf 函数未按要求读取格式

C - 大输入时的内存泄漏

c++ - boost 'release' 上的 ptr_container 泄漏?

c - strstr 函数中针的大小

c - 用文本文件中的数据填充数组

c - 在没有 MAX_ELEMENTS 的情况下初始化数组是否更好?

c - 如何使用 C 中先前定义的常量来定义静态常量?

debugging - 64 位版本的 Valgrind 是否能够解决 32 位程序的内存问题?

在C中将字符串的一部分复制到另一部分

c - 如何检查字符串是否在二进制文件中