#include <wx/protocol/http.h>
wxHTTP can be used to establish a connection to an HTTP server.
wxHTTP can thus be used to create a (basic) HTTP client.
Public Member Functions | |
wxHTTP () | |
Default constructor. More... | |
virtual | ~wxHTTP () |
Destructor will close the connection if connected. More... | |
virtual bool | Connect (const wxString &host) |
Connect to the HTTP server. More... | |
virtual bool | Connect (const wxString &host, unsigned short port) |
virtual bool | Connect (const wxSockAddress &addr, bool wait) |
Connects to a server using the specified address. More... | |
wxString | GetHeader (const wxString &header) const |
Returns the data attached with a field whose name is specified by header. More... | |
virtual wxInputStream * | GetInputStream (const wxString &path) |
Creates a new input stream on the specified path. More... | |
int | GetResponse () const |
Returns the HTTP response code returned by the server. More... | |
void | SetMethod (const wxString &method) |
Set HTTP method. More... | |
void | SetHeader (const wxString &header, const wxString &h_data) |
It sets data of a field to be sent during the next request to the HTTP server. More... | |
wxString | GetCookie (const wxString &cookie) const |
Returns the value of a cookie. More... | |
bool | HasCookies () const |
Returns true if there were cookies. More... | |
bool | SetPostBuffer (const wxString &contentType, const wxMemoryBuffer &data) |
Set the binary data to be posted to the server. More... | |
bool | SetPostText (const wxString &contentType, const wxString &data, const wxMBConv &conv=wxConvUTF8) |
Set the text to be posted to the server. More... | |
Public Member Functions inherited from wxProtocol | |
virtual bool | Abort ()=0 |
Abort the current stream. More... | |
virtual wxString | GetContentType () const |
Returns the type of the content of the last opened stream. More... | |
virtual wxProtocolError | GetError () const |
Returns the last occurred error. More... | |
bool | Reconnect () |
Tries to reestablish a previous opened connection (close and renegotiate connection). More... | |
virtual void | SetPassword (const wxString &user) |
Sets the authentication password. More... | |
virtual void | SetUser (const wxString &user) |
Sets the authentication user. More... | |
void | SetDefaultTimeout (wxUint32 Value) |
Sets a new default timeout for the network operations. More... | |
void | SetLog (wxProtocolLog *log) |
Set the logger, deleting the old one and taking ownership of this one. More... | |
wxProtocolLog * | GetLog () const |
Return the current logger, may be NULL. More... | |
wxProtocolLog * | DetachLog () |
Detach the existing logger without deleting it. More... | |
void | LogRequest (const wxString &str) |
Call wxProtocolLog::LogRequest() if we have a valid logger or do nothing otherwise. More... | |
void | LogResponse (const wxString &str) |
Call wxProtocolLog::LogResponse() if we have a valid logger or do nothing otherwise. More... | |
Public Member Functions inherited from wxSocketClient | |
wxSocketClient (wxSocketFlags flags=wxSOCKET_NONE) | |
Constructor. More... | |
virtual | ~wxSocketClient () |
Destructor. More... | |
bool | Connect (const wxSockAddress &address, const wxSockAddress &local, bool wait=true) |
Connects to a server using the specified address. More... | |
bool | WaitOnConnect (long seconds=-1, long milliseconds=0) |
Wait until a connection request completes, or until the specified timeout elapses. More... | |
Public Member Functions inherited from wxSocketBase | |
bool | Error () const |
Returns true if an error occurred in the last IO operation. More... | |
virtual bool | GetLocal (wxSockAddress &addr) const |
Return the local address of the socket. More... | |
virtual bool | GetPeer (wxSockAddress &addr) const |
Return the peer address field of the socket. More... | |
long | GetTimeout () const |
Return the socket timeout in seconds. More... | |
bool | IsConnected () const |
Returns true if the socket is connected. More... | |
bool | IsData () |
Check if the socket can be currently read or written. More... | |
bool | IsDisconnected () const |
Returns true if the socket is not connected. More... | |
bool | IsOk () const |
Returns true if the socket is initialized and ready and false in other cases. More... | |
wxUint32 | LastCount () const |
Returns the number of bytes read or written by the last IO call. More... | |
wxUint32 | LastReadCount () const |
Returns the number of bytes read by the last Read() or ReadMsg() call (receive direction only). More... | |
wxUint32 | LastWriteCount () const |
Returns the number of bytes written by the last Write() or WriteMsg() call (transmit direction only). More... | |
wxSocketError | LastError () const |
Returns the last wxSocket error. More... | |
void | RestoreState () |
Restore the previous state of the socket, as saved with SaveState(). More... | |
void | SaveState () |
Save the current state of the socket in a stack. More... | |
virtual bool | Close () |
Shut down the socket, disabling further transmission and reception of data and disable events for the socket and frees the associated system resources. More... | |
void | ShutdownOutput () |
Shuts down the writing end of the socket. More... | |
wxSocketBase & | Discard () |
Delete all bytes in the incoming queue. More... | |
wxSocketFlags | GetFlags () const |
Returns current IO flags, as set with SetFlags() More... | |
void | InterruptWait () |
Use this function to interrupt any wait operation currently in progress. More... | |
wxSocketBase & | Peek (void *buffer, wxUint32 nbytes) |
Peek into the socket by copying the next bytes which would be read by Read() into the provided buffer. More... | |
wxSocketBase & | Read (void *buffer, wxUint32 nbytes) |
Read up to the given number of bytes from the socket. More... | |
wxSocketBase & | ReadMsg (void *buffer, wxUint32 nbytes) |
Receive a message sent by WriteMsg(). More... | |
void | SetFlags (wxSocketFlags flags) |
Use SetFlags to customize IO operation for this socket. More... | |
virtual bool | SetLocal (const wxIPV4address &local) |
Set the local address and port to use. More... | |
void | SetTimeout (long seconds) |
Set the default socket timeout in seconds. More... | |
wxSocketBase & | Unread (const void *buffer, wxUint32 nbytes) |
Put the specified data into the input queue. More... | |
bool | Wait (long seconds=-1, long millisecond=0) |
Wait for any socket event. More... | |
bool | WaitForLost (long seconds=-1, long millisecond=0) |
Wait until the connection is lost. More... | |
bool | WaitForRead (long seconds=-1, long millisecond=0) |
Wait until the socket is readable. More... | |
bool | WaitForWrite (long seconds=-1, long millisecond=0) |
Wait until the socket becomes writable. More... | |
wxSocketBase & | Write (const void *buffer, wxUint32 nbytes) |
Write up to the given number of bytes to the socket. More... | |
wxSocketBase & | WriteMsg (const void *buffer, wxUint32 nbytes) |
Sends a buffer which can be read using ReadMsg(). More... | |
void * | GetClientData () const |
Returns a pointer of the client data for this socket, as set with SetClientData() More... | |
void | Notify (bool notify) |
According to the notify value, this function enables or disables socket events. More... | |
void | SetClientData (void *data) |
Sets user-supplied client data for this socket. More... | |
void | SetEventHandler (wxEvtHandler &handler, int id=-1) |
Sets an event handler to be called when a socket event occurs. More... | |
void | SetNotify (wxSocketEventFlags flags) |
Specifies which socket events are to be sent to the event handler. More... | |
wxSOCKET_T | GetSocket () const |
Returns the native socket descriptor. More... | |
wxSocketBase () | |
Default constructor. More... | |
virtual | ~wxSocketBase () |
Destructor. More... | |
bool | Destroy () |
Destroys the socket safely. More... | |
Public Member Functions inherited from wxObject | |
wxObject () | |
Default ctor; initializes to NULL the internal reference data. More... | |
wxObject (const wxObject &other) | |
Copy ctor. More... | |
virtual | ~wxObject () |
Destructor. More... | |
virtual wxClassInfo * | GetClassInfo () const |
This virtual function is redefined for every class that requires run-time type information, when using the wxDECLARE_CLASS macro (or similar). More... | |
wxObjectRefData * | GetRefData () const |
Returns the wxObject::m_refData pointer, i.e. the data referenced by this object. More... | |
bool | IsKindOf (const wxClassInfo *info) const |
Determines whether this class is a subclass of (or the same class as) the given class. More... | |
bool | IsSameAs (const wxObject &obj) const |
Returns true if this object has the same data pointer as obj. More... | |
void | Ref (const wxObject &clone) |
Makes this object refer to the data in clone. More... | |
void | SetRefData (wxObjectRefData *data) |
Sets the wxObject::m_refData pointer. More... | |
void | UnRef () |
Decrements the reference count in the associated data, and if it is zero, deletes the data. More... | |
void | UnShare () |
This is the same of AllocExclusive() but this method is public. More... | |
void | operator delete (void *buf) |
The delete operator is defined for debugging versions of the library only, when the identifier __WXDEBUG__ is defined. More... | |
void * | operator new (size_t size, const wxString &filename=NULL, int lineNum=0) |
The new operator is defined for debugging versions of the library only, when the identifier __WXDEBUG__ is defined. More... | |
Additional Inherited Members | |
Static Public Member Functions inherited from wxSocketBase | |
static bool | Initialize () |
Perform the initialization needed in order to use the sockets. More... | |
static void | Shutdown () |
Shut down the sockets. More... | |
Protected Member Functions inherited from wxObject | |
void | AllocExclusive () |
Ensure that this object's data is not shared with any other object. More... | |
virtual wxObjectRefData * | CreateRefData () const |
Creates a new instance of the wxObjectRefData-derived class specific to this object and returns it. More... | |
virtual wxObjectRefData * | CloneRefData (const wxObjectRefData *data) const |
Creates a new instance of the wxObjectRefData-derived class specific to this object and initializes it copying data. More... | |
Protected Attributes inherited from wxObject | |
wxObjectRefData * | m_refData |
Pointer to an object which is the object's reference-counted data. More... | |
wxHTTP::wxHTTP | ( | ) |
Default constructor.
|
virtual |
Destructor will close the connection if connected.
|
virtual |
Connects to a server using the specified address.
If wait is true, Connect() will wait until the connection completes.
If wait is false, Connect() will try to establish the connection and return immediately, without blocking the GUI. When used this way, even if Connect() returns false, the connection request can be completed later. To detect this, use WaitOnConnect(), or catch wxSOCKET_CONNECTION events (for successful establishment) and wxSOCKET_LOST events (for connection failure).
address | Address of the server. |
wait | If true, waits for the connection to complete. |
Reimplemented from wxSocketClient.
|
virtual |
Connect to the HTTP server.
By default, connection is made to the port 80 of the specified host. You may connect to a non-default port by specifying it explicitly using the second overload.
Currently wxHTTP only supports IPv4.
For the overload taking wxSockAddress, the wait argument is ignored.
|
virtual |
Returns the data attached with a field whose name is specified by header.
If the field doesn't exist, it will return an empty string and not a NULL string.
|
virtual |
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.
Note that you can still know the size of the file you are getting using wxStreamBase::GetSize(). However there is a limitation: in HTTP protocol, the size is not always specified so sometimes (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.
Implements wxProtocol.
int wxHTTP::GetResponse | ( | ) | const |
Returns the HTTP response code returned by the server.
Please refer to RFC 2616 for the list of responses.
bool wxHTTP::HasCookies | ( | ) | const |
Returns true if there were cookies.
It sets data of a field to be sent during the next request to the HTTP server.
The field name is specified by header and the content by h_data. This is a low level function and it assumes that you know what you are doing.
void wxHTTP::SetMethod | ( | const wxString & | method | ) |
Set HTTP method.
Set common or expanded HTTP method.
Overrides GET or POST methods that is used by default.
method | HTTP method name, e.g. "GET". |
bool wxHTTP::SetPostBuffer | ( | const wxString & | contentType, |
const wxMemoryBuffer & | data | ||
) |
Set the binary data to be posted to the server.
If a non-empty buffer is passed to this method, the next request will be an HTTP POST
instead of the default HTTP GET
and the given data will be posted as the body of this request.
For textual data a more convenient SetPostText() can be used instead.
contentType | The value of HTTP "Content-Type" header, e.g. "image/png". |
data | The data to post. |
bool wxHTTP::SetPostText | ( | const wxString & | contentType, |
const wxString & | data, | ||
const wxMBConv & | conv = wxConvUTF8 |
||
) |
Set the text to be posted to the server.
After a successful call to this method, the request will use HTTP POST
instead of the default GET
when it's executed.
Use SetPostBuffer() if you need to post non-textual data.
contentType | The value of HTTP "Content-Type" header, e.g. "text/html; charset=UTF-8". |
data | The data to post. |
conv | The conversion to use to convert data contents to a byte stream. Its value should be consistent with the charset parameter specified in contentType. |
POST'ed
correctly).