avoid to access invalid memory when received data length is the same as buffer size

This commit is contained in:
minggo 2016-06-03 11:39:01 +08:00
parent 66217b7bd1
commit b7b74f2328
1 changed files with 11 additions and 4 deletions

View File

@ -1946,6 +1946,12 @@ static void serverEntryPoint(unsigned int port)
listen(s, 1);
#define MAX_RECEIVED_SIZE 1024
#define BUF_SIZE MAX_RECEIVED_SIZE + 1
char buf[BUF_SIZE] = {0};
int readBytes = 0;
while (true) {
clientSocket = accept(s, NULL, NULL);
@ -1963,9 +1969,7 @@ static void serverEntryPoint(unsigned int port)
// process any input, send any output
clearBuffers();
char buf[1024] = {0};
int readBytes = 0;
while ((readBytes = (int)::recv(clientSocket, buf, sizeof(buf), 0)) > 0)
while ((readBytes = (int)::recv(clientSocket, buf, MAX_RECEIVED_SIZE, 0)) > 0)
{
buf[readBytes] = '\0';
// TRACE_DEBUGGER_SERVER("debug server : received command >%s", buf);
@ -1979,6 +1983,9 @@ static void serverEntryPoint(unsigned int port)
cc_closesocket(clientSocket);
}
} // while(true)
#undef BUF_SIZE
#undef MAX_RECEIVED_SIZE
}
bool JSBDebug_BufferWrite(JSContext* cx, unsigned argc, jsval* vp)