Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/hyperium/http
Rust HTTP types
https://github.com/hyperium/http
http rust
Last synced: 2 days ago
JSON representation
Rust HTTP types
- Host: GitHub
- URL: https://github.com/hyperium/http
- Owner: hyperium
- License: apache-2.0
- Created: 2017-03-14T18:21:23.000Z (almost 8 years ago)
- Default Branch: master
- Last Pushed: 2024-10-28T12:55:45.000Z (about 2 months ago)
- Last Synced: 2024-10-29T11:28:12.786Z (about 2 months ago)
- Topics: http, rust
- Language: Rust
- Homepage:
- Size: 664 KB
- Stars: 1,155
- Watchers: 37
- Forks: 291
- Open Issues: 162
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- License: LICENSE-APACHE
Awesome Lists containing this project
README
# HTTP
A general purpose library of common HTTP types
[![CI](https://github.com/hyperium/http/workflows/CI/badge.svg)](https://github.com/hyperium/http/actions?query=workflow%3ACI)
[![Crates.io](https://img.shields.io/crates/v/http.svg)](https://crates.io/crates/http)
[![Documentation](https://docs.rs/http/badge.svg)][dox]More information about this crate can be found in the [crate
documentation][dox].[dox]: https://docs.rs/http
## Usage
To use `http`, first add this to your `Cargo.toml`:
```toml
[dependencies]
http = "1.0"
```Next, add this to your crate:
```rust
use http::{Request, Response};fn main() {
// ...
}
```## Examples
Create an HTTP request:
```rust
use http::Request;fn main() {
let request = Request::builder()
.uri("https://www.rust-lang.org/")
.header("User-Agent", "awesome/1.0")
.body(())
.unwrap();
}
```Create an HTTP response:
```rust
use http::{Response, StatusCode};fn main() {
let response = Response::builder()
.status(StatusCode::MOVED_PERMANENTLY)
.header("Location", "https://www.rust-lang.org/install.html")
.body(())
.unwrap();
}
```# Supported Rust Versions
This project follows the [Tokio MSRV][msrv] and is currently set to `1.49`.
[msrv]: https://github.com/tokio-rs/tokio/#supported-rust-versions
# License
Licensed under either of
- Apache License, Version 2.0 ([LICENSE-APACHE](LICENSE-APACHE) or https://apache.org/licenses/LICENSE-2.0)
- MIT license ([LICENSE-MIT](LICENSE-MIT) or https://opensource.org/licenses/MIT)# Contribution
Unless you explicitly state otherwise, any contribution intentionally submitted
for inclusion in the work by you, as defined in the Apache-2.0 license, shall be
dual licensed as above, without any additional terms or conditions.