Welcome to Experts Exchange

Add your voice to the tech community where 5M+ people, just like you, are talking about what matters.

  • Help others & share knowledge
  • Earn cash & points
  • Learn & ask questions
Solved

CHTTPFile::SendRequest problem

Posted on 2003-10-26
5
2,526 Views
Last Modified: 2013-11-20
I am using CHTTPFile::SendRequest to Post data to a website.  This seems to work fine about 3/4 of the time.  The problem is that after posting 2 or 3 pages, the next page I try to post wont work.  It will just hang on the SendRequest call untill finally an exception is thrown with the error text, "The operation timed out".  

I have a couple questions:

1 ) When this happens it takes about 3 minutes for the operator to time out.  Is there any way I can shorten this time?  3 minutes is ridicuously too long, as a successful call takes less than 2 seconds.

2) Why is this timing out at all?  It happens like clockwork; after 2-4 successful calls, I will have this problem.  It is always the same error (The operation timed out).  I know that the server is still accessible, because I can open another instance of my program and post data just fine.

Here is pseudo code on how I perform my post operation:

CInternetSession session;
CHTTPConnection* m_pWebConnection;
CHTTPFile* m_pWebFile;
CString m_strWebHeaders = _T("Content-Type: application/x-www-form-urlencoded");
m_pWebConnection = session.GetHttpConnection(...);
m_pWebFile = m_pWebConnection->OpenRequest(CHttpConnection::HTTP_VERB_POST,<some string>);
try {
  m_pWebFile->SendRequest(m_strWebHeaders,<data>, <data length>);  // this will time out about 3/4 of the time
}
catch(CInternetException * pe)
// This is where it catches the timout error      
0
Comment
Question by:lwinkenb
  • 3
  • 2
5 Comments
 
LVL 23

Accepted Solution

by:
Roshan Davis earned 500 total points
ID: 9622090
Did you tried
CHttpFile::SetOption with flag "INTERNET_OPTION_CONNECT_TIMEOUT"

Rosh :)
0
 
LVL 23

Expert Comment

by:Roshan Davis
ID: 9622099
Try this one for 20 seconds

session.SetOption(INTERNET_OPTION_CONNECT_TIMEOUT, 1000 * 20);

Rosh :)
0
 
LVL 5

Author Comment

by:lwinkenb
ID: 9623450
thanks roshmon, ill give that a try to set the timeout.  Any ideas why it would timeout in the first place?
0
 
LVL 5

Author Comment

by:lwinkenb
ID: 9623486
well, I think I just figured out my problem.  I wasnt closing my CHTTPFile after the method ended.  When I started closing it, the timeouts stopped.

Well learning how to set the timeout was worth 500 points to me :)
0
 
LVL 23

Expert Comment

by:Roshan Davis
ID: 9624792
>>  I wasnt closing my CHTTPFile after the method ended.
Ohh  yes, that could be the actual problem.

Thankx
0

Featured Post

Free Tool: ZipGrep

ZipGrep is a utility that can list and search zip (.war, .ear, .jar, etc) archives for text patterns, without the need to extract the archive's contents.

One of a set of tools we're offering as a way to say thank you for being a part of the community.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

Suggested Solutions

Here is how to use MFC's automatic Radio Button handling in your dialog boxes and forms.  Beginner programmers usually start with a OnClick handler for each radio button and that's just not the right way to go.  MFC has a very cool system for handli…
This is to be the first in a series of articles demonstrating the development of a complete windows based application using the MFC classes.  I’ll try to keep each article focused on one (or a couple) of the tasks that one may meet.   Introductio…
This video will show you how to get GIT to work in Eclipse.   It will walk you through how to install the EGit plugin in eclipse and how to checkout an existing repository.

828 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