Body parsing plugins for the Iron web framework.
```rust extern crate iron; extern crate bodyparser; extern crate persistent;
use persistent::Read; use iron::status; use iron::prelude::*;
struct MyStructure {
a: String,
b: Option
fn log_body(req: &mut Request) -> IronResult
let json_body = req.get::<bodyparser::Json>();
match json_body {
Ok(Some(json_body)) => println!("Parsed body:\n{}", json_body),
Ok(None) => println!("No body"),
Err(err) => println!("Error: {:?}", err)
}
let struct_body = req.get::<bodyparser::Struct<MyStructure>>();
match struct_body {
Ok(Some(struct_body)) => println!("Parsed body:\n{:?}", struct_body),
Ok(None) => println!("No body"),
Err(err) => println!("Error: {:?}", err)
}
Ok(Response::with(status::Ok))
}
const MAXBODYLENGTH: usize = 1024 * 1024 * 10;
// curl -i "localhost:3000/" -H "application/json" -d '{"name":"jason","age":"2"}'
// and check out the printed json in your terminal.
fn main() {
let mut chain = Chain::new(logbody);
chain.linkbefore(Read::
body-parser is a part of Iron's core bundle. It contains:
If you're using a Cargo.toml
to manage dependencies, just add body-parser to the toml:
```toml [dependencies.bodyparser]
git = "https://github.com/iron/body-parser.git" ```
Otherwise, cargo build
, and the rlib will be in your target
directory.
Along with the online documentation,
you can build a local copy with make doc
.
One of us (@reem, @zzmp,
@theptrk, @mcreinhard)
is usually on #iron
on the mozilla irc. Come say hi and ask any questions you might have.
We are also usually on #rust
and #rust-webdev
.