Solved

Winsock Recv/Send problem

Posted on 2009-07-13
3
1,588 Views
Last Modified: 2013-11-17
I've been having one hell of a problem with a program I'm making.  Basically, it's inter-process communication using sockets. I've done sockets for years, and just recently started running into this roadblock that I can't figure out.  I've gotten it to connect to the "server" (which is just another program running a bind on 127.0.0.1), but when we exchange information, I've used a set of MessageBox's to show me the data going between the two.  The MessageBox's hault program execution until user input, but from what I understand, messages are supposed to queue up, right? Anyways, this is what I'm getting (an example conversation):

-Connect to localhost-
server SEND: 0,CONNECTED
client RECV: 0,CONNECTED_TO_SERVER

client SEND: 1,COMMAND,1,ARGS,HERE
server RECV: 1,COMMAND,1,ARGS,HERE

server SEND: 2,FLUSH
client RECV: 2,FLUSHCTED_TO_SERVER

-----

You'll notice that my client is recv'ing but it almost looks like the buffer/recv queue I'm using isn't being flushed properly and it has remnants of previous packets in it.

Maybe it has something to do with my methodology? I'm using a while() loop on a non-blocking socket inside of a different thread in my GUI, and skipping past anything with a WSAEWOULDBLOCK error to recieve everything.  I hope the experts aren't laughing at me at this point :P

Here's the strange part...I'm doing EVERYTHING I can to zero this buffer out though..during every loop iteration, I set my buffer's 0 index to 0x00 like so:
recvBuff[0] = 0x00;
Which should set the string to null (just to make sure I'm not overwiting what I had)..from the server side, I used a MessageBox to show me what the server was sending, and it IS sending properly formatted packets, so I know the problem is on my client end...I even tried taking the recvBuff upon a successful recv call and doing a strncpy into a NEW buffer based on the size of data receieved like so:

lResult = recv(socket,recvBuff,512,0);
if(lResult > 0)
{
   strncpy(buff2,recvBuff,lResult);
  ..etc..
}

It probably has a whole lot to do with my loop, but I can't for the LIFE of me figure out why my buffer isn't clearing/why my socket recv data is all mashing together.

OH I FORGOT -- If I put a message box after the recv call showing the AMOUNT of data I received like so:

sprintf(buffer,"%i -- Number of bytes recvd",lResult);
MessageBox(0,buffer,"Recv",0);

Then it actually shows me the correct number AND parses correctly..but only if that message box is there. Is it a speed issue? What the hell is going on?? lol

Any help at all would be GREATLY appreciated...and if you can think of a better way to do winsock in C++ (I'm using MingW via Ultimate++), perhaps async sockets or something, PLEASE let me know. I'm about to smash my computer due to this lol :P

-Kevin
0
Comment
Question by:ProjectZIG
3 Comments
 
LVL 16

Expert Comment

by:George Tokas
ID: 24848619
With C++ Builder implementation is easy...
What compiler are you using??

George Tokas.
0
 

Author Comment

by:ProjectZIG
ID: 24850672
I'm using MinGW 32 and the Ultimate++ development environment.

http://www.ultimatepp.org/
0
 
LVL 27

Accepted Solution

by:
BigRat earned 500 total points
ID: 24961690
>> I'm using isn't being flushed properly and it has remnants of previous packets in it.

Which looks as if you're treating the socket connection as a packet sending/receiving system.

>> I've done sockets for years

Which suggests that you know that the system is a stream system.

Could you be a little more specific on what "client SEND: 1,COMMAND,1,ARGS,HERE" is?

In particular what exactly contitues a "packet"?
0

Featured Post

Maximize Your Threat Intelligence Reporting

Reporting is one of the most important and least talked about aspects of a world-class threat intelligence program. Here’s how to do it right.

Join & Write a Comment

Does the idea of dealing with bits scare or confuse you? Does it seem like a waste of time in an age where we all have terabytes of storage? If so, you're missing out on one of the core tools in every professional programmer's toolbox. Learn how to …
Displaying an arrayList in a listView using the default adapter is rarely the best solution. To get full control of your display data, and to be able to refresh it after editing, requires the use of a custom adapter.
THe viewer will learn how to use NetBeans IDE 8.0 for Windows to perform CRUD operations on a MySql database.
The viewer will learn how to synchronize PHP projects with a remote server in NetBeans IDE 8.0 for Windows.

706 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question

Need Help in Real-Time?

Connect with top rated Experts

14 Experts available now in Live!

Get 1:1 Help Now