File HTTPClient.h
FileList > arduino > libraries > ext > HTTPClient > HTTPClient.h
Go to the source code of this file.
#include <Arduino.h>
#include <WiFiClient.h>
#include <WiFiClientSecure.h>
#include <memory>
#include <vector>
Classes
Type | Name |
---|---|
struct | Cookie |
class | HTTPClient |
struct | RequestArgument |
Public Types
Type | Name |
---|---|
typedef std::vector< Cookie > | CookieJar |
typedef std::unique_ptr< TransportTraits > | TransportTraitsPtr |
enum | followRedirects_t |
enum | t_http_codes HTTP codes see RFC7231. |
enum | transferEncoding_t |
Macros
Type | Name |
---|---|
define | HTTPCLIENT_1_1_COMPATIBLE |
define | HTTPCLIENT_DEFAULT_TCP_TIMEOUT (5000) Cookie jar support. |
define | HTTPC_ERROR_CONNECTION_LOST (-5) |
define | HTTPC_ERROR_CONNECTION_REFUSED (-1) HTTP client errors. |
define | HTTPC_ERROR_ENCODING (-9) |
define | HTTPC_ERROR_NOT_CONNECTED (-4) |
define | HTTPC_ERROR_NO_HTTP_SERVER (-7) |
define | HTTPC_ERROR_NO_STREAM (-6) |
define | HTTPC_ERROR_READ_TIMEOUT (-11) |
define | HTTPC_ERROR_SEND_HEADER_FAILED (-2) |
define | HTTPC_ERROR_SEND_PAYLOAD_FAILED (-3) |
define | HTTPC_ERROR_STREAM_WRITE (-10) |
define | HTTPC_ERROR_TOO_LESS_RAM (-8) |
define | HTTP_TCP_BUFFER_SIZE (1460) size for the stream handling |
Public Types Documentation
typedef CookieJar
typedef TransportTraitsPtr
enum followRedirects_t
enum followRedirects_t {
HTTPC_DISABLE_FOLLOW_REDIRECTS,
HTTPC_STRICT_FOLLOW_REDIRECTS,
HTTPC_FORCE_FOLLOW_REDIRECTS
};
redirection follow mode.
* HTTPC_DISABLE_FOLLOW_REDIRECTS
- no redirection will be followed.
* HTTPC_STRICT_FOLLOW_REDIRECTS
- strict RFC2616, only requests using GET or HEAD methods will be redirected (using the same method), since the RFC requires end-user confirmation in other cases.
* HTTPC_FORCE_FOLLOW_REDIRECTS
- all redirections will be followed, regardless of a used method. New request will use the same method, and they will include the same body data and the same headers. In the sense of the RFC, it's just like every redirection is confirmed.
enum t_http_codes
enum t_http_codes {
HTTP_CODE_CONTINUE = 100,
HTTP_CODE_SWITCHING_PROTOCOLS = 101,
HTTP_CODE_PROCESSING = 102,
HTTP_CODE_OK = 200,
HTTP_CODE_CREATED = 201,
HTTP_CODE_ACCEPTED = 202,
HTTP_CODE_NON_AUTHORITATIVE_INFORMATION = 203,
HTTP_CODE_NO_CONTENT = 204,
HTTP_CODE_RESET_CONTENT = 205,
HTTP_CODE_PARTIAL_CONTENT = 206,
HTTP_CODE_MULTI_STATUS = 207,
HTTP_CODE_ALREADY_REPORTED = 208,
HTTP_CODE_IM_USED = 226,
HTTP_CODE_MULTIPLE_CHOICES = 300,
HTTP_CODE_MOVED_PERMANENTLY = 301,
HTTP_CODE_FOUND = 302,
HTTP_CODE_SEE_OTHER = 303,
HTTP_CODE_NOT_MODIFIED = 304,
HTTP_CODE_USE_PROXY = 305,
HTTP_CODE_TEMPORARY_REDIRECT = 307,
HTTP_CODE_PERMANENT_REDIRECT = 308,
HTTP_CODE_BAD_REQUEST = 400,
HTTP_CODE_UNAUTHORIZED = 401,
HTTP_CODE_PAYMENT_REQUIRED = 402,
HTTP_CODE_FORBIDDEN = 403,
HTTP_CODE_NOT_FOUND = 404,
HTTP_CODE_METHOD_NOT_ALLOWED = 405,
HTTP_CODE_NOT_ACCEPTABLE = 406,
HTTP_CODE_PROXY_AUTHENTICATION_REQUIRED = 407,
HTTP_CODE_REQUEST_TIMEOUT = 408,
HTTP_CODE_CONFLICT = 409,
HTTP_CODE_GONE = 410,
HTTP_CODE_LENGTH_REQUIRED = 411,
HTTP_CODE_PRECONDITION_FAILED = 412,
HTTP_CODE_PAYLOAD_TOO_LARGE = 413,
HTTP_CODE_URI_TOO_LONG = 414,
HTTP_CODE_UNSUPPORTED_MEDIA_TYPE = 415,
HTTP_CODE_RANGE_NOT_SATISFIABLE = 416,
HTTP_CODE_EXPECTATION_FAILED = 417,
HTTP_CODE_MISDIRECTED_REQUEST = 421,
HTTP_CODE_UNPROCESSABLE_ENTITY = 422,
HTTP_CODE_LOCKED = 423,
HTTP_CODE_FAILED_DEPENDENCY = 424,
HTTP_CODE_UPGRADE_REQUIRED = 426,
HTTP_CODE_PRECONDITION_REQUIRED = 428,
HTTP_CODE_TOO_MANY_REQUESTS = 429,
HTTP_CODE_REQUEST_HEADER_FIELDS_TOO_LARGE = 431,
HTTP_CODE_INTERNAL_SERVER_ERROR = 500,
HTTP_CODE_NOT_IMPLEMENTED = 501,
HTTP_CODE_BAD_GATEWAY = 502,
HTTP_CODE_SERVICE_UNAVAILABLE = 503,
HTTP_CODE_GATEWAY_TIMEOUT = 504,
HTTP_CODE_HTTP_VERSION_NOT_SUPPORTED = 505,
HTTP_CODE_VARIANT_ALSO_NEGOTIATES = 506,
HTTP_CODE_INSUFFICIENT_STORAGE = 507,
HTTP_CODE_LOOP_DETECTED = 508,
HTTP_CODE_NOT_EXTENDED = 510,
HTTP_CODE_NETWORK_AUTHENTICATION_REQUIRED = 511
};
enum transferEncoding_t
Macro Definition Documentation
define HTTPCLIENT_1_1_COMPATIBLE
HTTPClient.h
Created on: 02.11.2015
Copyright (c) 2015 Markus Sattler. All rights reserved. This file is part of the HTTPClient for Arduino. Port to ESP32 by Evandro Luis Copercini (2017), changed fingerprints to CA verification.
This library is free software; you can redistribute it and/or modify it under the terms of the GNU Lesser General Public License as published by the Free Software Foundation; either version 2.1 of the License, or (at your option) any later version.
This library is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License for more details.
You should have received a copy of the GNU Lesser General Public License along with this library; if not, write to the Free Software Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
define HTTPCLIENT_DEFAULT_TCP_TIMEOUT
define HTTPC_ERROR_CONNECTION_LOST
define HTTPC_ERROR_CONNECTION_REFUSED
define HTTPC_ERROR_ENCODING
define HTTPC_ERROR_NOT_CONNECTED
define HTTPC_ERROR_NO_HTTP_SERVER
define HTTPC_ERROR_NO_STREAM
define HTTPC_ERROR_READ_TIMEOUT
define HTTPC_ERROR_SEND_HEADER_FAILED
define HTTPC_ERROR_SEND_PAYLOAD_FAILED
define HTTPC_ERROR_STREAM_WRITE
define HTTPC_ERROR_TOO_LESS_RAM
define HTTP_TCP_BUFFER_SIZE
The documentation for this class was generated from the following file cores/common/arduino/libraries/ext/HTTPClient/HTTPClient.h