I’m trying to get a simple send and receive UDP program working, but I’m having a bit of trouble with saving the received data. As far as I can tell the data is being sent and received properly, as I’ve printed it out on both ends. Before I write the data to the file (if I just print out the received chunk) it doesn’t have any extra characters, so I’m a bit lost as to where they are coming from.
When I append each chunk of received data to the file it adds a “^P^B^GÐ^?” after every chunk written. for example one of the chunks ended with “We, therefore^P^B^GÐ^?,” instead of “We, therefore,”.
Any help is appreciated, thanks in advance.
UPDATE:
I’ve seemed to have gotten things working semi-better, I’m now having an issue with it replacing the first character of every chunk with a null character, for example:
“^@N CONGRESS, July 4, 1776.” instead of “IN CONGRESS, July 4, 1776.”
It’s doing this for the first char of every chunk received, I’ve tried multiple debug print statements but can’t seem to figure out what the issue is.
Here is my Receive and Send functions:
void receiveFile() {
int addr_len, bytesRead;
char recvData[BUFSIZE]; // Buffer to store received data
struct sockaddr_in server_addr, client_addr;
// Set up struct to receive data from our port and address
server_addr.sin_family = AF_INET;
server_addr.sin_port = htons(port);
server_addr.sin_addr.s_addr = INADDR_ANY;
bzero(&(server_addr.sin_zero), 8);
addr_len = sizeof (struct sockaddr);
printf("\nWaiting for data on port %d\n", port);
//Keep reading data from the socket
while (1) {
FILE *fp;
fp=fopen("dummyfile.txt", "ab");
memset(recvData, 0, BUFSIZE);
bytesRead = recvfrom(sock, recvData, BUFSIZE, 0,
(struct sockaddr *) &client_addr, &addr_len);
int x;
for(x = 0; x < bytesRead; x++) {
fputc(recvData[x], fp);
}
// Print out who we're receiving from and what we're recieving
printf("Receiving data from %s : %d\n", inet_ntoa(client_addr.sin_addr),
ntohs(client_addr.sin_port));
fclose(fp);
}}
Here is the Send Function:
void sendFile() {
// Announce who we're sending data to
if(DEBUG) { printf("\nSending %s to %s:%d\n", filename, address, port); }
// Open file
FILE * file = fopen(filename, "rb");
if (file == NULL) {
perror("Invalid File\n");
exit(1);
}
// Get size of the file
fseek(file, 0, SEEK_END);
int filesize = ftell(file);
rewind(file);
int curPos = 0;
int dataSize = 0;
while(curPos < filesize) {
struct sockaddr_in server_addr;
struct hostent *recvr;
char sendData[BUFSIZE]; // stores message to be sent
memset(sendData, 0, BUFSIZE);
int byte, i;
for(i = 0; i < BUFSIZE; i++){
if((filesize - curPos) > 0) {
byte = fgetc(file);
sendData[i] = byte;
curPos++;
dataSize++;
}
else { break; }
}
recvr = gethostbyname(address);
server_addr.sin_family = AF_INET;
server_addr.sin_port = htons(port);
server_addr.sin_addr = *((struct in_addr *) recvr->h_addr);
bzero(&(server_addr.sin_zero), 8);
if(DEBUG) {
char tempData[1201];
strncpy(tempData, sendData, 1200);
tempData[1201] ='\0';
printf("%s\n\n\n\n\n", tempData);
}
sendto(sock, sendData, dataSize, 0,
(struct sockaddr *) &server_addr, sizeof (struct sockaddr));
dataSize = 0;
}
fclose(file);}
What happens when you change the printing to:
There is a guarantee that
recvfrom()will not null terminate your messages; you would have to transmit the null terminator yourself.I can’t tell what your residual problem is. I have the following to complete programs working back to back. I’ve scrutinized the saved file for NULs with no problem.
I ran them as:
recv.c
send.c
posixver.h
stderr.c and stderr.h
Actually, not standard at all, except in my code. The functions used have the declarations:
The first records the program name. The second reports an error message and exits; the third reports a message and returns; the fourth reports an error message and adds error information from ‘errno’ and ‘strerror()’ if there is any to use; the last reports on how to use the program – in this case, the programs accept no arguments. The full source code (quite large) is available from the IIUG Software site as part of the SQLCMD package available there, and various other programs that I’ve also submitted there.