官术网_书友最值得收藏!

Returning JSON data

The previous section returned data in plain text. This is unusual in a web service and rarely satisfactory. Usually, web services return data in JSON, XML, or another structured format. The json_db project is identical to the memory_db project, except for its returning data in the JSON format.

First of all, let's see what happens when the same curl commands from the previous section are executed on it, as follows:

  • The insertions have the same behavior because they just printed a number.
  • The first query should print the following: [1,2,3]. The three numbers are in an array, and so they are enclosed in brackets.
  • The second query should print the following: "Mary Jane". The name is a string, and so it is enclosed in quotation marks.
  • The third query should print the following: [[2,"Jonathan"],[3,"Mary Jane"]]. The sequence of persons is an array of two records, and each of them is an array of two values, which are a number and a string.

Now, let's see the differences in the code of this project with respect to the previous one.

In the Cargo.toml file, one dependency has been added, as follows:

serde_json = "1.0"

This is needed to serialize the data in JSON format.

In the main.rs file, the get_all_persons_ids function (instead of returning simply a string) has the following code:

HttpResponse::Ok()
.content_type("application/json")
.body(
json!(db_conn.get_all_persons_ids().collect::<Vec<_>>())
.to_string())

First, a response with a status code Ok is created; then, its content type is set to application/json, to let the client know how to interpret the data it will receive; and lastly, its body is set, using the json macro taken from the serde_json crate. This macro takes an expression—in this case, with type, Vec<Person>—and returns a serde_json::Value value. Now, we need a string, and so to_string() is called. Notice that the json! macro requires its argument to implement the Serialize trait or to be convertible into a string.

The get_person_name_by_idget_persons, and insert_person functions have similar changes. The main function has no changes. The db_access.rs files are identical.

主站蜘蛛池模板: 阜城县| 昌图县| 乃东县| 和田市| 平武县| 康定县| 高要市| 滁州市| 正定县| 深水埗区| 汽车| 老河口市| 扎兰屯市| 景东| 连平县| 洪泽县| 冀州市| 南充市| 苏尼特右旗| 绍兴县| 凤冈县| 肥东县| 安塞县| 白城市| 兰考县| 治多县| 南投县| 平乡县| 苏尼特右旗| 昌邑市| 桃源县| 惠东县| 阿荣旗| 蓬莱市| 商水县| 芦山县| 张家界市| 徐水县| 佛坪县| 隆昌县| 象山县|