Rust json處理
JSON是一種比較重要的格式,尤其是現在的web開發領域,JSON相比於傳統的XML更加容易操作和減小傳輸。
Rust中的JSON處理依賴 cargo 中的rustc-serialize模塊
###先簡單的創建一個Rust項目工程
#![allow(unused)] fn main() { $ cargo new json_data --bin }
生成文件樹:
vagrant@ubuntu-14:~/tmp/test/rustprimer$ tree
.
`-- json_data
|-- Cargo.toml
`-- src
`-- main.rs
生成項目json_data
,項目下文件介紹:
- Caogo.toml ,文件中填寫一些項目的相關信息,比如版本號,聯繫人,項目名,文件的內容如下:
[package]
name = "json_data"
version = "0.1.0"
authors = ["wangxxx <xxxxx@qq.com>"]
[dependencies]
- src 中放置項目的源代碼,main.rs 為項目的入口文件。
###一些必要的瞭解
rustc-serialize 這個是第三方的模塊,需要從cargo下載。 下載很簡單,只需修改一下cargo.toml文件就行了.
[package]
name = "json_data"
version = "0.1.0"
authors = ["wangxxx <xxxxx@qq.com>"]
[dependencies]
rustc-serialize = "0.3.18"
然後執行在當前目錄執行:
$ cargo build
注意一個問題由於國內網絡訪問github不穩定,這些第三方庫很多託管在github上,所以可能需要修改你的 網絡訪問
- 在安裝Rust之後,會在你的用戶目錄之下生成一個
.cargo
文件夾,進入這個文件夾 - 在
.cargo
文件夾下,創建一個config
文件,在文件中填寫中科大軟件源,可能以後會出現其他的源,先用這個 config
文件內容如下
[registry]
index = "git://crates.mirrors.ustc.edu.cn/index"
cargo build 執行之後的提示信息
Updating registry `git://crates.mirrors.ustc.edu.cn/index`
Downloading rustc-serialize v0.3.18 (registry git://crates.mirrors.ustc.edu.cn/index)
Compiling rustc-serialize v0.3.18 (registry git://crates.mirrors.ustc.edu.cn/index)
Compiling json_data v0.1.0 (file:///home/vagrant/tmp/test/rustprimer/json_data)
再次執行tree命令:
.
|-- Cargo.lock
|-- Cargo.toml
|-- src
| `-- main.rs
`-- target
`-- debug
|-- build
|-- deps
| `-- librustc_serialize-d27006e102b906b6.rlib
|-- examples
|-- json_data
`-- native
可以看到多了很多文件,重點關注cargo.lock
,開打文件:
[root]
name = "json_data"
version = "0.1.0"
dependencies = [
"rustc-serialize 0.3.18 (registry+git://crates.mirrors.ustc.edu.cn/index)",
]
[[package]]
name = "rustc-serialize"
version = "0.3.18"
source = "registry+git://crates.mirrors.ustc.edu.cn/index"
是關於項目編譯的一些依賴信息
還有生成了target文件夾,生成了可執行文件json_data,因為main.rs中的執行結果就是打印hello world
$ cargo run
Hello, world!
###開始寫代碼 直接使用官方的 rustc_serialize 中的例子:
extern crate rustc_serialize; // 引入rustc_serialize模塊 use rustc_serialize::json; // Automatically generate `RustcDecodable` and `RustcEncodable` trait // implementations // 定義TestStruct #[derive(RustcDecodable, RustcEncodable)] pub struct TestStruct { data_int: u8, data_str: String, data_vector: Vec<u8>, } fn main() { // 初始化TestStruct let object = TestStruct { data_int: 1, data_str: "homura".to_string(), data_vector: vec![2,3,4,5], }; // Serialize using `json::encode` // 將TestStruct轉意為字符串 let encoded = json::encode(&object).unwrap(); println!("{}",encoded); // Deserialize using `json::decode` // 將json字符串中的數據轉化成TestStruct對應的數據,相當於初始化 let decoded: TestStruct = json::decode(&encoded).unwrap(); println!("{:?}",decoded.data_vector); }
當然我們也可以在文本中作為api的返回結果使用,下來的章節中,我們將討論這個問題