- Single header library interface
libnhr.h
with public methods - Thread safe
- Send/receive logic in background thread
- GET.
- Send url encoded request, default.
- POST
- Send url encoded request, default.
- Send deflate compressed url encoded request.
- Send gzip compressed url encoded request.
- Send chunked request body.
- Send file/data.
- Response
- Process response with chunked transfer encoding.
- Process deflate compressed content encoding.
- Process gzip compressed content encoding.
All features are enabled by default. But it's possible to disable. See table below:
Preprocessor | CMake (Boolean value) | Description |
---|---|---|
NHR_NO_GET | NHR_OPT_NO_GET | Send GET requests. |
NHR_NO_POST | NHR_OPT_NO_POST | Send POST requests. |
NHR_NO_POST_DATA | NHR_OPT_NO_POST_DATA | Send POST requests with data/file parameters. |
NHR_NO_RECV_CHUNKS | NHR_OPT_NO_RECV_CHUNKS | Process received response with chunked transfer encoding, e.g. "Transfer-Encoding: chunked". |
NHR_NO_SEND_CHUNKS | NHR_OPT_NO_SEND_CHUNKS | Send big request as chunks. |
NHR_NO_GZIP | NHR_OPT_NO_GZIP | Post gzip or deflate compressed url encoded parameters. |
Process gzip or deflate compressed response body. |
Use (install or update) latest CMake build system, need version 2.8 or later.
cd libnhr
mkdir build
cd build
cmake -DCMAKE_BUILD_TYPE=Release ..
make
Example how to disable, for instance
POST
method, with CMake.cmake -DCMAKE_BUILD_TYPE=Release -DNHR_OPT_NO_POST:BOOL=ON ..
Build for Android with Android NDK
- Download and install Android NDK.
- Navigate to installed Android NDK folder.
- Execute ndk-build script with project path parameter:
cd <path_to_Android_NDK>
./ndk-build NDK_PROJECT_PATH=<path_to_libnhr>/builds/android
Replace
<path_to_Android_NDK>
and<path_to_libnhr>
with actual paths.
To disable some method(s) need to add Preprocessor flag from table to your
Android.mk
or gradle ndk section.
Without build system, just use single header libnhr.h
and all content from source folder src
.
// Define variable or field for the request
nhr_request _request = NULL;
............
// Create request object
_request = nhr_request_create();
// Combined url: "http://api.ipify.org"
nhr_request_set_url(_request, "http", "api.ipify.org", "/", 80);
// or
// Combined url: "http://isithackday.com/arrpi.php"
nhr_request_set_url(_request, "http", "isithackday.com", "/arrpi.php", 80);
nhr_request_set_method(_request, nhr_method_GET); // GET
// or
nhr_request_set_method(_request, nhr_method_POST); // POST
// Add HTTP headers
nhr_request_add_header_field(_request, "Cache-control", "no-cache");
nhr_request_add_header_field(_request, "Accept-Charset", "utf-8");
// Optional: in a case of POST, send gzip or deflate compressed url encoded parameters
nhr_request_add_header_field(request, k_nhr_content_encoding, k_nhr_gzip); // gzip
nhr_request_add_header_field(request, k_nhr_content_encoding, k_nhr_deflate); // deflate
............
// Add request parameters
nhr_request_add_parameter(_request, "format", "json");
nhr_request_add_parameter(_request, "text", "Hello%20world"); // url encoded if not POST and no data params
// Add request parameters(including data parameter). Method should be POST
const char * fileContent = "If the user selected a second (image) file, the user agent might construct the parts as follows";
const size_t fileContentSize = strlen(fileContent);
nhr_request_add_data_parameter(_request, "text", "file_name.txt", fileContent, fileContentSize);
nhr_request_add_parameter(_request, "text", "Hello world"); // not url encoded if POST with data params
static void on_request_error(nhr_request request, nhr_error_code error_code) {
_request = NULL; // Clean up previously stored request variable or field
//TODO: process `error_code`
}
static void on_request_response(nhr_request request, nhr_response response) {
_request = NULL; // Clean up previously stored request variable or field
char * body = nhr_response_get_body(response);
unsigned int body_length = nhr_response_get_body_length(response);
if (body && body_length) {
//TODO: process response body data
}
}
..................
// Set request callbacks
nhr_request_set_on_recvd_response(_request, &on_request_response);
nhr_request_set_on_error(_request, &on_request_error);
nhr_request_send(_request);
The MIT License (MIT)
Copyright (c) 2016 - 2019 Oleh Kulykov info@resident.name
Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:
The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.