2008-03-08 13:52:38 +00:00
|
|
|
/////////////////////////////////////////////////////////////////////////////
|
|
|
|
// Name: protocol/http.h
|
2008-03-10 15:24:38 +00:00
|
|
|
// Purpose: interface of wxHTTP
|
2008-03-08 13:52:38 +00:00
|
|
|
// Author: wxWidgets team
|
|
|
|
// RCS-ID: $Id$
|
2010-07-13 13:29:13 +00:00
|
|
|
// Licence: wxWindows licence
|
2008-03-08 13:52:38 +00:00
|
|
|
/////////////////////////////////////////////////////////////////////////////
|
|
|
|
|
|
|
|
/**
|
|
|
|
@class wxHTTP
|
2008-03-08 14:43:31 +00:00
|
|
|
|
2008-04-10 21:31:05 +00:00
|
|
|
wxHTTP can be used to establish a connection to an HTTP server.
|
2008-03-08 14:43:31 +00:00
|
|
|
|
2009-01-16 15:08:13 +00:00
|
|
|
wxHTTP can thus be used to create a (basic) HTTP @b client.
|
|
|
|
|
2008-03-08 13:52:38 +00:00
|
|
|
@library{wxnet}
|
|
|
|
@category{net}
|
2008-03-08 14:43:31 +00:00
|
|
|
|
2008-03-10 15:24:38 +00:00
|
|
|
@see wxSocketBase, wxURL
|
2008-03-08 13:52:38 +00:00
|
|
|
*/
|
|
|
|
class wxHTTP : public wxProtocol
|
|
|
|
{
|
|
|
|
public:
|
2009-01-16 15:08:13 +00:00
|
|
|
/**
|
|
|
|
Default constructor.
|
|
|
|
*/
|
|
|
|
wxHTTP();
|
|
|
|
|
|
|
|
/**
|
|
|
|
Destructor will close the connection if connected.
|
|
|
|
*/
|
|
|
|
virtual ~wxHTTP();
|
|
|
|
|
2008-09-24 13:16:17 +00:00
|
|
|
//@{
|
|
|
|
/**
|
|
|
|
Connect to the HTTP server.
|
|
|
|
|
|
|
|
By default, connection is made to the port 80 of the specified @a host.
|
|
|
|
You may connect to a non-default port by specifying it explicitly using
|
|
|
|
the second overload.
|
2010-05-19 12:36:28 +00:00
|
|
|
|
|
|
|
Currently wxHTTP only supports IPv4.
|
|
|
|
|
|
|
|
For the overload taking wxSockAddress, the @a wait argument is ignored.
|
2008-09-24 13:16:17 +00:00
|
|
|
*/
|
2009-01-10 23:44:44 +00:00
|
|
|
virtual bool Connect(const wxString& host);
|
|
|
|
virtual bool Connect(const wxString& host, unsigned short port);
|
2010-05-19 12:36:28 +00:00
|
|
|
virtual bool Connect(const wxSockAddress& addr, bool wait);
|
2008-09-24 13:16:17 +00:00
|
|
|
//@}
|
|
|
|
|
2008-03-08 13:52:38 +00:00
|
|
|
/**
|
2009-01-16 15:08:13 +00:00
|
|
|
Returns the data attached with a field whose name is specified by @a header.
|
2008-04-10 21:31:05 +00:00
|
|
|
If the field doesn't exist, it will return an empty string and not a @NULL string.
|
|
|
|
|
|
|
|
@note
|
|
|
|
The header is not case-sensitive, i.e. "CONTENT-TYPE" and "content-type"
|
|
|
|
represent the same header.
|
2008-03-08 13:52:38 +00:00
|
|
|
*/
|
2008-09-27 11:21:10 +00:00
|
|
|
wxString GetHeader(const wxString& header) const;
|
2008-03-08 13:52:38 +00:00
|
|
|
|
|
|
|
/**
|
2008-04-10 21:31:05 +00:00
|
|
|
Creates a new input stream on the specified path.
|
|
|
|
|
|
|
|
Notice that this stream is unseekable, i.e. SeekI() and TellI() methods
|
|
|
|
shouldn't be used.
|
|
|
|
|
2008-03-08 14:43:31 +00:00
|
|
|
Note that you can still know the size of the file you are getting using
|
2008-04-10 21:31:05 +00:00
|
|
|
wxStreamBase::GetSize(). However there is a limitation: in HTTP protocol,
|
|
|
|
the size is not always specified so sometimes @c (size_t)-1 can returned to
|
|
|
|
indicate that the size is unknown.
|
|
|
|
In such case, you may want to use wxInputStream::LastRead() method in a loop
|
|
|
|
to get the total size.
|
|
|
|
|
2008-05-11 01:38:53 +00:00
|
|
|
@return Returns the initialized stream. You must delete it yourself
|
2008-04-10 21:31:05 +00:00
|
|
|
once you don't use it anymore and this must be done before
|
2008-03-09 12:33:59 +00:00
|
|
|
the wxHTTP object itself is destroyed. The destructor
|
|
|
|
closes the network connection. The next time you will
|
|
|
|
try to get a file the network connection will have to
|
|
|
|
be reestablished, but you don't have to take care of
|
|
|
|
this since wxHTTP reestablishes it automatically.
|
2008-04-10 21:31:05 +00:00
|
|
|
|
2008-03-09 12:33:59 +00:00
|
|
|
@see wxInputStream
|
2008-03-08 13:52:38 +00:00
|
|
|
*/
|
2008-09-27 11:21:10 +00:00
|
|
|
virtual wxInputStream* GetInputStream(const wxString& path);
|
2008-03-08 13:52:38 +00:00
|
|
|
|
|
|
|
/**
|
2008-04-10 21:31:05 +00:00
|
|
|
Returns the HTTP response code returned by the server.
|
|
|
|
|
|
|
|
Please refer to RFC 2616 for the list of responses.
|
2008-03-08 13:52:38 +00:00
|
|
|
*/
|
2009-01-16 15:08:13 +00:00
|
|
|
int GetResponse() const;
|
2008-03-08 13:52:38 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
It sets data of a field to be sent during the next request to the HTTP server.
|
2008-04-10 21:31:05 +00:00
|
|
|
|
2009-01-16 15:08:13 +00:00
|
|
|
The field name is specified by @a header and the content by @a h_data.
|
2008-03-08 13:52:38 +00:00
|
|
|
This is a low level function and it assumes that you know what you are doing.
|
|
|
|
*/
|
|
|
|
void SetHeader(const wxString& header, const wxString& h_data);
|
2009-09-26 19:47:23 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
Returns the value of a cookie.
|
|
|
|
*/
|
|
|
|
|
|
|
|
wxString GetCookie(const wxString& cookie) const;
|
|
|
|
|
|
|
|
/**
|
|
|
|
Returns @true if there were cookies.
|
|
|
|
*/
|
|
|
|
bool HasCookies() const;
|
2010-05-19 12:36:36 +00:00
|
|
|
|
|
|
|
/**
|
2012-01-20 12:22:25 +00:00
|
|
|
Set the binary data to be posted to the server.
|
2010-05-19 12:36:36 +00:00
|
|
|
|
2012-01-20 12:22:25 +00:00
|
|
|
If a non-empty buffer is passed to this method, the next request will
|
|
|
|
be an HTTP @c POST instead of the default HTTP @c GET and the given @a
|
|
|
|
data will be posted as the body of this request.
|
|
|
|
|
|
|
|
For textual data a more convenient SetPostText() can be used instead.
|
|
|
|
|
|
|
|
@param contentType
|
|
|
|
The value of HTTP "Content-Type" header, e.g. "image/png".
|
|
|
|
@param data
|
|
|
|
The data to post.
|
|
|
|
@return
|
|
|
|
@true if any data was passed in or @false if the buffer was empty.
|
|
|
|
|
|
|
|
@since 2.9.4
|
|
|
|
*/
|
|
|
|
bool SetPostBuffer(const wxString& contentType, const wxMemoryBuffer& data);
|
|
|
|
|
|
|
|
/**
|
|
|
|
Set the text to be posted to the server.
|
|
|
|
|
|
|
|
After a successful call to this method, the request will use HTTP @c
|
|
|
|
POST instead of the default @c GET when it's executed.
|
|
|
|
|
|
|
|
Use SetPostBuffer() if you need to post non-textual data.
|
|
|
|
|
|
|
|
@param contentType
|
|
|
|
The value of HTTP "Content-Type" header, e.g. "text/html;
|
|
|
|
charset=UTF-8".
|
|
|
|
@param data
|
|
|
|
The data to post.
|
|
|
|
@param conv
|
|
|
|
The conversion to use to convert @a data contents to a byte stream.
|
|
|
|
Its value should be consistent with the charset parameter specified
|
|
|
|
in @a contentType.
|
|
|
|
@return
|
|
|
|
@true if string was non-empty and was successfully converted using
|
|
|
|
the given @a conv or @false otherwise (in this case this request
|
|
|
|
won't be @c POST'ed correctly).
|
|
|
|
|
|
|
|
@since 2.9.4
|
2010-05-19 12:36:36 +00:00
|
|
|
*/
|
2012-01-20 12:22:25 +00:00
|
|
|
bool SetPostText(const wxString& contentType,
|
|
|
|
const wxString& data,
|
|
|
|
const wxMBConv& conv = wxConvUTF8);
|
2008-03-08 13:52:38 +00:00
|
|
|
};
|
2008-03-10 15:24:38 +00:00
|
|
|
|