Reputation:
I send a UDP request to a server, although it returns me the right answer on wireshark but in my code with " recvfrom " I get what I sent.
Code :
char* udp_recv;
udp_recv = (char*)malloc(256);
s = socket(AF_INET, SOCK_DGRAM, IPPROTO_UDP);
for (i; i < 1; i++)
{
String^ delimStr = ":";
array<Char>^ delimiter = delimStr->ToCharArray();
array<String^>^ addrPort = addr[i]->Split(delimiter);
char *cAddr, *cPort, *cPartAddr;
cAddr = (char*)malloc(16);
cPort = (char*)malloc(16);
cPartAddr = (char*)malloc(16);
ConvertStringToChar(addrPort[0], cAddr, 16);
ConvertStringToChar(addrPort[1], cPort, 16);
SOCKADDR_IN udpbind;
udpbind.sin_family = AF_INET;
udpbind.sin_addr.s_addr = INADDR_ANY;
udpbind.sin_port = htons((u_short)atoi(cPort));
if (bind(s, (struct sockaddr*)&udpbind, sizeof(udpbind)) < 0) std::cout << "Erreur" << std::endl;
delimStr = ".";
delimiter = delimStr->ToCharArray();
array<String^>^ partAddr = addrPort[0]->Split(delimiter);
std::string send("SAMP");
int j = 0;
for (j; j < 4; j++)
{
ConvertStringToChar(partAddr[j], cPartAddr, 16);
send += (char)atoi(cPartAddr);
}
send += (char)(atoi(cPort) & 0xFF);
send += (char)(atoi(cPort) >> 8 & 0xFF);
send += "i";
server.sin_addr.s_addr = inet_addr(cAddr);
server.sin_family = AF_INET;
server.sin_port = htons((u_short)atoi(cPort));
sendto(s, (char*)send.c_str(), strlen((char*)send.c_str()), 0, (struct sockaddr *)&server, sizeof(server));
struct sockaddr_in recv;
int client_len = sizeof(recv);
recv_size = recvfrom(s, udp_recv, 256, 0, NULL, NULL);
udp_recv[recv_size] = '\0';
std::cout << udp_recv << std::endl;
free(cPartAddr);
free(cAddr);
free(cPort);
}
closesocket(s);
Thanks !
Upvotes: 0
Views: 334
Reputation: 104569
This may not be the answer, but this looks suspicious:
udp_recv = (char*)malloc(256);
...
recv_size = recvfrom(s, udp_recv, 256, 0, NULL, NULL);
udp_recv[recv_size] = '\0';
Two immediate problems:
If the number of bytes received is actually 256, then you'll be assigning udp_recv[256]=0
.
If the result is an error recvfrom returns -1 (SOCKET_ERROR). You'll be assigning udp_recv[-1]=0
;
In both cases, the valid index ranges of udp_recv is [0..255]. -1 and 256 are invalid index ranges. Thus, undefined behavior.
Check for socket error and allocate the buffer to be 1 more byte larger than what you declare the buffer size to be.
Upvotes: 1