nanoFramework.System.Net.Http.Client
1.5.30
Prefix Reserved
See the version list below for details.
dotnet add package nanoFramework.System.Net.Http.Client --version 1.5.30
NuGet\Install-Package nanoFramework.System.Net.Http.Client -Version 1.5.30
<PackageReference Include="nanoFramework.System.Net.Http.Client" Version="1.5.30" />
paket add nanoFramework.System.Net.Http.Client --version 1.5.30
#r "nuget: nanoFramework.System.Net.Http.Client, 1.5.30"
// Install nanoFramework.System.Net.Http.Client as a Cake Addin #addin nuget:?package=nanoFramework.System.Net.Http.Client&version=1.5.30 // Install nanoFramework.System.Net.Http.Client as a Cake Tool #tool nuget:?package=nanoFramework.System.Net.Http.Client&version=1.5.30
Welcome to the .NET nanoFramework System.Net.Http Library repository
Build status
Component | Build Status | NuGet Package |
---|---|---|
System.Net.Http | ||
System.Net.Http.Client | ||
System.Net.Http.Server |
Usage examples
The API, classes and namespaces in this library follow, as close as possible, the .NET ones.
Exceptions are the lack of async calls, generics and the Task, async/await model. The names reflect that by dropping the Async suffix and not returning Task
and the lack of the overloaded methods with CancelationToken
parameters.
Also worth mentioning is the need to pass the CA root certificate to HttpClient
in order to be able to validate the server certificate.
HttpClient calling REST services
HttpClient
makes it very easy to connect and consume REST services.
In order to use it, one has to create the object and them perform the calls. Note that HttpClient
is meant to be reused throughout the application lifecycle. There is no need to create a new instance every time a call has to be performed. Like this:
static readonly HttpClient _httpClient = new HttpClient();
To pass the CA root certificate allowing to validate the secure server certificate. The CA root cert can also come from a binary file or text file from a resource.
_httpClient.HttpsAuthentCert = new X509Certificate(
@"-----BEGIN CERTIFICATE-----
MIIEDzCCAvegAwIBAgIBADANBgkqhkiG9w0BAQUFADBoMQswCQYDVQQGEwJVUzEl
MCMGA1UEChMcU3RhcmZpZWxkIFRlY2hub2xvZ2llcywgSW5jLjEyMDAGA1UECxMp
U3RhcmZpZWxkIENsYXNzIDIgQ2VydGlmaWNhdGlvbiBBdXRob3JpdHkwHhcNMDQw
NjI5MTczOTE2WhcNMzQwNjI5MTczOTE2WjBoMQswCQYDVQQGEwJVUzElMCMGA1UE
ChMcU3RhcmZpZWxkIFRlY2hub2xvZ2llcywgSW5jLjEyMDAGA1UECxMpU3RhcmZp
ZWxkIENsYXNzIDIgQ2VydGlmaWNhdGlvbiBBdXRob3JpdHkwggEgMA0GCSqGSIb3
DQEBAQUAA4IBDQAwggEIAoIBAQC3Msj+6XGmBIWtDBFk385N78gDGIc/oav7PKaf
8MOh2tTYbitTkPskpD6E8J7oX+zlJ0T1KKY/e97gKvDIr1MvnsoFAZMej2YcOadN
+lq2cwQlZut3f+dZxkqZJRRU6ybH838Z1TBwj6+wRir/resp7defqgSHo9T5iaU0
X9tDkYI22WY8sbi5gv2cOj4QyDvvBmVmepsZGD3/cVE8MC5fvj13c7JdBmzDI1aa
K4UmkhynArPkPw2vCHmCuDY96pzTNbO8acr1zJ3o/WSNF4Azbl5KXZnJHoe0nRrA
1W4TNSNe35tfPe/W93bC6j67eA0cQmdrBNj41tpvi/JEoAGrAgEDo4HFMIHCMB0G
A1UdDgQWBBS/X7fRzt0fhvRbVazc1xDCDqmI5zCBkgYDVR0jBIGKMIGHgBS/X7fR
zt0fhvRbVazc1xDCDqmI56FspGowaDELMAkGA1UEBhMCVVMxJTAjBgNVBAoTHFN0
YXJmaWVsZCBUZWNobm9sb2dpZXMsIEluYy4xMjAwBgNVBAsTKVN0YXJmaWVsZCBD
bGFzcyAyIENlcnRpZmljYXRpb24gQXV0aG9yaXR5ggEAMAwGA1UdEwQFMAMBAf8w
DQYJKoZIhvcNAQEFBQADggEBAAWdP4id0ckaVaGsafPzWdqbAYcaT1epoXkJKtv3
L7IezMdeatiDh6GX70k1PncGQVhiv45YuApnP+yz3SFmH8lU+nLMPUxA2IGvd56D
eruix/U0F47ZEUD0/CwqTRV/p2JdLiXTAAsgGh1o+Re49L2L7ShZ3U0WixeDyLJl
xy16paq8U4Zt3VekyvggQQto8PT7dL5WXXp59fkdheMtlb71cZBDzI0fmgAKhynp
VSJYACPq4xJDKVtHCN2MQWplBqjlIapBtJUhlbl90TSrE9atvNziPTnNvT51cKEY
WQPJIrSPnNVeKtelttQKbfi3QBFGmh95DmK/D5fs4C8fF5Q=
-----END CERTIFICATE-----");
It's possible to add HTTP headers that will be sent along with each request.
_httpClient.DefaultRequestHeaders.Add("x-ms-blob-type", "BlockBlob");
Perform a HTTP GET request
Here's a example of a HTTP request to read some content as a string:
HttpResponseMessage response = _httpClient.Get("https://httpbin.org/get");
response.EnsureSuccessStatusCode();
var responseBody = response.Content.ReadAsString();
The above call would return something similar to the following, which can be output in Visual Studio by calling Debug.WriteLine(responseBody)
:
{
"args": {},
"headers": {
"Host": "httpbin.org",
"X-Amzn-Trace-Id": "Root=1-6214aad3-38e5f8357bdf90530300eb5f",
"X-Ms-Blob-Type": "BlockBlob"
},
"origin": "5.249.47.208",
"url": "https://httpbin.org/get"
}
Note the call to response.EnsureSuccessStatusCode();
. This will throw an HttpRequestException
in case the status code from the HTTP request is not a successful one.
Perform a HTTP POST request
Follows an example of a HTTP request performing POST request to send some json content to an endpoint.
var content = new StringContent("{\"someProperty\":\"someValue\"}", Encoding.UTF8, "application/json");
var result = _httpClient.Post("https://httpbin.org/anything", content);
result.EnsureSuccessStatusCode();
Worth noting that the json content above it's presented as a simple string to simplify the code. There is a json library available to help with serializing and deserializing from/to C# classes, even the most complex ones.
Again, note the call to response.EnsureSuccessStatusCode();
to make sure the HTTP request was successfully performed.
Download binary content to a file
Using HttpClient
makes it easy to deal with binary content too. Here's an example of how to download a file from a webserver.
HttpResponseMessage response = _httpClient.Get("https://storage-on-the-cloud.net/file-with-binary-content");
response.EnsureSuccessStatusCode();
using FileStream fs = new FileStream($"I:\\i-am-a-binary-file.bin", FileMode.Create, FileAccess.Write);
response.Content.ReadAsStream().CopyTo(fs);
Debugging through a reverse proxy
When code is deployed to a MCU it might be desirable to let the device connect to your development machine running IIS Express. This can be achieved with a proxy such as this one. Be aware that this leads to SocketExceptions with the current version of nanoFramework System.Net.Http when sending consecutive requests to your development machine. A simple retry mechanism in Debug mode will get around this.
Feedback and documentation
For documentation, providing feedback, issues and finding out how to contribute please refer to the Home repo.
Join our Discord community here.
Credits
The list of contributors to this project can be found at CONTRIBUTORS.
License
The nanoFramework Class Libraries are licensed under the MIT license.
Code of Conduct
This project has adopted the code of conduct defined by the Contributor Covenant to clarify expected behaviour in our community. For more information see the .NET Foundation Code of Conduct.
.NET Foundation
This project is supported by the .NET Foundation.
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET Framework | net is compatible. |
-
- nanoFramework.CoreLibrary (>= 1.12.0)
- nanoFramework.Runtime.Events (>= 1.11.1)
- nanoFramework.System.Collections (>= 1.4.0)
- nanoFramework.System.Net (>= 1.10.24)
- nanoFramework.System.Text (>= 1.2.7)
- nanoFramework.System.Threading (>= 1.1.8)
NuGet packages
This package is not used by any NuGet packages.
GitHub repositories (2)
Showing the top 2 popular GitHub repositories that depend on nanoFramework.System.Net.Http.Client:
Repository | Stars |
---|---|
dotnet/samples
Sample code referenced by the .NET documentation
|
|
nanoframework/Samples
🍬 Code samples from the nanoFramework team used in testing, proof of concepts and other explorational endeavours
|
Version | Downloads | Last updated |
---|---|---|
1.5.150 | 473 | 9/26/2024 |
1.5.145 | 206 | 7/30/2024 |
1.5.138 | 305 | 5/13/2024 |
1.5.136 | 166 | 5/10/2024 |
1.5.134 | 218 | 4/8/2024 |
1.5.132 | 113 | 4/8/2024 |
1.5.130 | 163 | 4/3/2024 |
1.5.128 | 115 | 4/3/2024 |
1.5.125 | 313 | 1/29/2024 |
1.5.118 | 139 | 1/24/2024 |
1.5.113 | 414 | 11/10/2023 |
1.5.110 | 144 | 11/9/2023 |
1.5.108 | 160 | 11/9/2023 |
1.5.106 | 162 | 11/3/2023 |
1.5.104 | 256 | 10/10/2023 |
1.5.102 | 200 | 10/4/2023 |
1.5.99 | 339 | 8/8/2023 |
1.5.97 | 273 | 7/27/2023 |
1.5.95 | 157 | 7/27/2023 |
1.5.84 | 615 | 2/17/2023 |
1.5.82 | 388 | 1/24/2023 |
1.5.78 | 364 | 12/28/2022 |
1.5.75 | 322 | 12/28/2022 |
1.5.73 | 327 | 12/28/2022 |
1.5.70 | 331 | 12/27/2022 |
1.5.68 | 339 | 12/22/2022 |
1.5.61 | 536 | 11/23/2022 |
1.5.54 | 506 | 10/26/2022 |
1.5.52 | 376 | 10/26/2022 |
1.5.50 | 421 | 10/26/2022 |
1.5.48 | 409 | 10/25/2022 |
1.5.45 | 407 | 10/25/2022 |
1.5.43 | 432 | 10/24/2022 |
1.5.41 | 439 | 10/24/2022 |
1.5.39 | 413 | 10/24/2022 |
1.5.37 | 423 | 10/23/2022 |
1.5.35 | 428 | 10/23/2022 |
1.5.30 | 453 | 10/10/2022 |
1.5.27 | 396 | 10/8/2022 |
1.5.24 | 486 | 9/22/2022 |
1.5.22 | 439 | 9/22/2022 |
1.5.20 | 538 | 9/15/2022 |
1.5.18 | 455 | 9/15/2022 |
1.5.13 | 649 | 8/5/2022 |
1.5.10 | 420 | 8/4/2022 |
1.5.8 | 422 | 8/4/2022 |
1.5.6 | 445 | 8/4/2022 |
1.5.4 | 441 | 8/3/2022 |
1.5.2 | 448 | 8/3/2022 |
1.4.0.25 | 459 | 8/3/2022 |
1.4.0.23 | 616 | 6/13/2022 |
1.4.0.21 | 460 | 6/8/2022 |
1.4.0.19 | 458 | 6/8/2022 |
1.4.0.14 | 511 | 5/26/2022 |
1.4.0.12 | 488 | 5/18/2022 |
1.4.0.10 | 509 | 5/3/2022 |
1.4.0 | 600 | 3/28/2022 |
1.4.0-preview.52 | 135 | 3/28/2022 |
1.4.0-preview.51 | 126 | 3/28/2022 |
1.4.0-preview.50 | 126 | 3/28/2022 |
1.4.0-preview.48 | 127 | 3/28/2022 |
1.4.0-preview.47 | 125 | 3/28/2022 |
1.4.0-preview.46 | 128 | 3/28/2022 |
1.4.0-preview.44 | 144 | 3/17/2022 |
1.4.0-preview.43 | 128 | 3/17/2022 |
1.4.0-preview.42 | 139 | 3/14/2022 |
1.4.0-preview.41 | 130 | 3/14/2022 |
1.4.0-preview.40 | 121 | 3/14/2022 |
1.4.0-preview.39 | 125 | 3/14/2022 |
1.4.0-preview.37 | 132 | 3/14/2022 |
1.4.0-preview.36 | 142 | 3/8/2022 |
1.4.0-preview.35 | 133 | 3/8/2022 |
1.4.0-preview.33 | 141 | 3/4/2022 |
1.4.0-preview.32 | 134 | 3/3/2022 |
1.4.0-preview.31 | 132 | 3/2/2022 |
1.4.0-preview.29 | 172 | 2/28/2022 |
1.4.0-preview.28 | 198 | 2/24/2022 |
1.4.0-preview.26 | 151 | 2/17/2022 |
1.4.0-preview.24 | 132 | 2/17/2022 |
1.4.0-preview.22 | 160 | 2/6/2022 |
1.4.0-preview.21 | 151 | 2/4/2022 |
1.4.0-preview.19 | 150 | 2/4/2022 |
1.4.0-preview.18 | 151 | 1/28/2022 |
1.4.0-preview.16 | 147 | 1/28/2022 |
1.4.0-preview.15 | 149 | 1/28/2022 |
1.4.0-preview.13 | 150 | 1/28/2022 |
1.4.0-preview.12 | 146 | 1/21/2022 |
1.4.0-preview.6 | 162 | 1/12/2022 |
1.4.0-preview.5 | 148 | 1/12/2022 |
1.4.0-preview.4 | 143 | 1/11/2022 |
1.4.0-preview.3 | 146 | 1/11/2022 |
1.3.7-preview.8 | 147 | 1/5/2022 |
1.3.7-preview.7 | 158 | 1/3/2022 |
1.3.7-preview.6 | 146 | 1/3/2022 |
1.3.7-preview.5 | 148 | 1/3/2022 |
1.3.7-preview.4 | 146 | 12/30/2021 |
1.3.7-preview.3 | 148 | 12/28/2021 |
1.3.6 | 571 | 12/3/2021 |
1.3.6-preview.23 | 146 | 12/3/2021 |
1.3.6-preview.21 | 153 | 12/3/2021 |
1.3.6-preview.20 | 159 | 12/2/2021 |
1.3.6-preview.19 | 168 | 12/2/2021 |
1.3.6-preview.18 | 151 | 12/2/2021 |
1.3.6-preview.17 | 160 | 12/2/2021 |
1.3.6-preview.16 | 158 | 12/2/2021 |
1.3.6-preview.14 | 161 | 12/2/2021 |
1.3.6-preview.12 | 155 | 12/2/2021 |
1.3.6-preview.10 | 160 | 12/1/2021 |
1.3.6-preview.7 | 160 | 12/1/2021 |
1.3.6-preview.1 | 229 | 11/11/2021 |
1.3.5-preview.8 | 167 | 10/22/2021 |
1.3.5-preview.5 | 183 | 10/18/2021 |
1.3.4 | 1,052 | 7/16/2021 |
1.3.4-preview.78 | 166 | 7/16/2021 |
1.3.4-preview.76 | 171 | 7/16/2021 |
1.3.4-preview.74 | 174 | 7/16/2021 |
1.3.4-preview.72 | 185 | 7/15/2021 |
1.3.4-preview.70 | 184 | 7/14/2021 |
1.3.4-preview.68 | 618 | 6/19/2021 |
1.3.4-preview.66 | 271 | 6/19/2021 |
1.3.4-preview.64 | 176 | 6/17/2021 |
1.3.4-preview.62 | 185 | 6/7/2021 |
1.3.4-preview.60 | 177 | 6/7/2021 |
1.3.4-preview.58 | 204 | 6/7/2021 |
1.3.4-preview.56 | 215 | 6/6/2021 |
1.3.4-preview.54 | 216 | 6/3/2021 |
1.3.4-preview.52 | 173 | 6/2/2021 |
1.3.4-preview.50 | 184 | 6/1/2021 |
1.3.4-preview.48 | 197 | 6/1/2021 |
1.3.4-preview.41 | 205 | 5/25/2021 |
1.3.4-preview.39 | 231 | 5/21/2021 |
1.3.4-preview.37 | 233 | 5/20/2021 |
1.3.4-preview.35 | 176 | 5/19/2021 |
1.3.4-preview.33 | 181 | 5/19/2021 |
1.3.4-preview.31 | 201 | 5/19/2021 |
1.3.4-preview.29 | 179 | 5/15/2021 |
1.3.4-preview.27 | 179 | 5/15/2021 |
1.3.4-preview.25 | 178 | 5/15/2021 |
1.3.4-preview.23 | 185 | 5/13/2021 |
1.3.4-preview.22 | 179 | 5/13/2021 |
1.3.4-preview.20 | 196 | 5/11/2021 |
1.3.4-preview.18 | 244 | 5/6/2021 |
1.3.4-preview.16 | 180 | 5/6/2021 |
1.3.4-preview.14 | 166 | 5/5/2021 |
1.3.4-preview.13 | 164 | 5/5/2021 |
1.3.4-preview.10 | 199 | 4/10/2021 |
1.3.4-preview.9 | 211 | 4/9/2021 |
1.3.4-preview.7 | 186 | 4/5/2021 |
1.3.3-preview.65 | 236 | 3/20/2021 |
1.3.3-preview.62 | 212 | 3/19/2021 |
1.3.3-preview.60 | 174 | 3/17/2021 |
1.3.3-preview.57 | 177 | 3/17/2021 |
1.3.3-preview.55 | 190 | 3/2/2021 |
1.3.3-preview.50 | 392 | 1/19/2021 |
1.3.3-preview.47 | 195 | 1/6/2021 |
1.3.3-preview.40 | 189 | 12/29/2020 |
1.3.3-preview.34 | 260 | 12/7/2020 |
1.3.3-preview.32 | 223 | 12/7/2020 |
1.3.3-preview.27 | 247 | 11/3/2020 |
1.3.3-preview.25 | 252 | 10/26/2020 |
1.3.3-preview.23 | 267 | 10/21/2020 |
1.3.3-preview.17 | 252 | 10/20/2020 |
1.3.3-preview.15 | 321 | 10/1/2020 |
1.3.3-preview.11 | 247 | 9/30/2020 |
1.3.3-preview.9 | 249 | 9/30/2020 |
1.3.3-preview.7 | 270 | 9/27/2020 |
1.3.3-preview.5 | 271 | 9/27/2020 |
1.3.3-preview.1 | 244 | 9/24/2020 |
1.3.2-preview.3 | 270 | 9/19/2020 |
1.3.2-preview.1 | 328 | 8/25/2020 |
1.3.1-preview.6 | 285 | 7/2/2020 |
1.3.1-preview.3 | 323 | 6/30/2020 |
1.3.0 | 566 | 6/16/2020 |
1.3.0-rc.3 | 301 | 6/16/2020 |
1.3.0-preview.11 | 310 | 6/16/2020 |
1.3.0-preview.9 | 237 | 6/16/2020 |
1.3.0-preview.7 | 242 | 6/16/2020 |
1.3.0-alpha.12 | 303 | 6/16/2020 |
1.3.0-alpha.10 | 238 | 6/16/2020 |
1.3.0-alpha.8 | 242 | 6/16/2020 |
1.2.2 | 465 | 6/12/2020 |
1.2.2-preview.41 | 245 | 6/12/2020 |
1.2.2-preview.39 | 261 | 6/12/2020 |
1.2.2-preview.34 | 261 | 6/3/2020 |
1.2.2-preview.33 | 272 | 6/3/2020 |
1.2.2-preview.31 | 371 | 5/31/2020 |
1.2.2-preview.30 | 253 | 5/31/2020 |
1.2.2-preview.29 | 284 | 5/31/2020 |
1.2.2-preview.28 | 277 | 5/29/2020 |
1.2.2-preview.27 | 280 | 5/8/2020 |
1.2.2-preview.26 | 276 | 5/8/2020 |
1.2.2-preview.25 | 258 | 4/27/2020 |
1.2.2-preview.24 | 251 | 4/24/2020 |
1.2.2-preview.23 | 245 | 4/21/2020 |
1.2.2-preview.22 | 297 | 4/16/2020 |
1.2.2-preview.19 | 287 | 4/16/2020 |
1.2.2-preview.18 | 264 | 4/14/2020 |
1.2.2-preview.17 | 256 | 4/14/2020 |
1.2.2-preview.16 | 264 | 4/14/2020 |
1.2.2-preview.15 | 290 | 3/25/2020 |
1.2.2-preview.14 | 300 | 3/15/2020 |
1.2.2-preview.13 | 262 | 3/10/2020 |
1.2.2-preview.12 | 254 | 3/10/2020 |
1.2.2-preview.10 | 252 | 3/10/2020 |
1.2.2-preview.8 | 258 | 3/10/2020 |
1.2.2-preview.7 | 258 | 3/10/2020 |
1.2.2-preview.6 | 282 | 3/9/2020 |
1.2.2-preview.5 | 281 | 3/9/2020 |
1.2.2-preview.4 | 261 | 3/6/2020 |
1.2.2-preview.3 | 310 | 1/13/2020 |
1.2.2-preview.2 | 320 | 11/14/2019 |
1.2.2-preview.1 | 272 | 11/12/2019 |
1.2.2-alpha.42 | 244 | 6/12/2020 |
1.2.2-alpha.40 | 269 | 6/12/2020 |
1.2.2-alpha.38 | 296 | 6/11/2020 |
1.2.2-alpha.35 | 262 | 6/3/2020 |
1.2.2-alpha.34 | 271 | 6/3/2020 |
1.2.2-alpha.32 | 366 | 5/31/2020 |
1.2.2-alpha.31 | 284 | 5/31/2020 |
1.2.2-alpha.30 | 283 | 5/30/2020 |
1.2.2-alpha.29 | 271 | 5/29/2020 |
1.2.2-alpha.28 | 276 | 5/8/2020 |
1.2.2-alpha.27 | 269 | 5/8/2020 |
1.2.2-alpha.26 | 253 | 4/27/2020 |
1.2.2-alpha.23 | 289 | 4/16/2020 |
1.2.2-alpha.21 | 277 | 4/16/2020 |
1.2.2-alpha.20 | 276 | 4/16/2020 |
1.2.2-alpha.19 | 252 | 4/14/2020 |
1.2.2-alpha.18 | 258 | 4/14/2020 |
1.2.2-alpha.17 | 250 | 4/14/2020 |
1.2.2-alpha.16 | 295 | 3/25/2020 |
1.2.2-alpha.15 | 300 | 3/15/2020 |
1.2.2-alpha.14 | 253 | 3/10/2020 |
1.2.2-alpha.13 | 245 | 3/10/2020 |
1.2.2-alpha.11 | 253 | 3/10/2020 |
1.2.2-alpha.10 | 262 | 3/10/2020 |
1.2.2-alpha.9 | 260 | 3/10/2020 |
1.2.2-alpha.8 | 284 | 3/9/2020 |
1.2.2-alpha.7 | 285 | 3/9/2020 |
1.2.2-alpha.6 | 294 | 3/9/2020 |
1.2.1-preview.3 | 269 | 11/8/2019 |
1.2.1-preview.1 | 277 | 11/5/2019 |
1.2.0-preview.3 | 271 | 10/18/2019 |
1.1.0 | 598 | 10/17/2019 |
1.1.0-preview.3 | 277 | 10/17/2019 |
1.0.8-preview.7 | 267 | 10/17/2019 |
1.0.8-preview.5 | 295 | 10/15/2019 |
1.0.8-preview.4 | 282 | 9/30/2019 |
1.0.8-preview.1 | 294 | 8/30/2019 |
1.0.7-preview.1 | 297 | 8/30/2019 |
1.0.6-preview.33 | 300 | 8/19/2019 |
1.0.6-preview.30 | 296 | 7/19/2019 |
1.0.6-preview.26 | 307 | 6/23/2019 |
1.0.6-preview.19 | 326 | 6/22/2019 |
1.0.6-preview.17 | 324 | 6/18/2019 |
1.0.5-preview-028 | 494 | 4/5/2019 |
1.0.5-preview-026 | 502 | 4/5/2019 |