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

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.

主站蜘蛛池模板: 凤城市| 德州市| 安龙县| 琼中| 安福县| 双辽市| 宜城市| 昌图县| 云安县| 化德县| 仁寿县| 斗六市| 望奎县| 旬邑县| 常熟市| 博客| 敖汉旗| 河源市| 霞浦县| 巴楚县| 吉水县| 读书| 武胜县| 天等县| 弥渡县| 嘉兴市| 沈丘县| 白玉县| 太谷县| 翁牛特旗| 库伦旗| 浮梁县| 巨鹿县| 古蔺县| 蛟河市| 张家港市| 定远县| 吉安市| 松原市| 辽阳市| 改则县|