Solved

CHTTPFile::SendRequest problem

Posted on 2003-10-26
5
2,494 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

Is Your Active Directory as Secure as You Think?

More than 75% of all records are compromised because of the loss or theft of a privileged credential. Experts have been exploring Active Directory infrastructure to identify key threats and establish best practices for keeping data safe. Attend this month’s webinar to learn more.

Question has a verified solution.

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

Introduction: Load and Save to file, Document-View interaction inside the SDI. Continuing from the second article about sudoku.   Open the project in visual studio. From the class view select CSudokuDoc and double click to open the header …
Exception Handling is in the core of any application that is able to dignify its name. In this article, I'll guide you through the process of writing a DRY (Don't Repeat Yourself) Exception Handling mechanism, using Aspect Oriented Programming.
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.
Here's a very brief overview of the methods PRTG Network Monitor (https://www.paessler.com/prtg) offers for monitoring bandwidth, to help you decide which methods you´d like to investigate in more detail.  The methods are covered in more detail in o…

914 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

12 Experts available now in Live!

Get 1:1 Help Now