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

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.

主站蜘蛛池模板: 天水市| 千阳县| 汪清县| 河北省| 长岭县| 光山县| 民权县| 六安市| 内乡县| 枝江市| 卢氏县| 揭东县| 古丈县| 韶山市| 蚌埠市| 望江县| 临汾市| 晋中市| 江阴市| 鹰潭市| 衢州市| 敖汉旗| 荃湾区| 叙永县| 通州市| 嘉峪关市| 马关县| 长宁县| 许昌县| 禄劝| 泾阳县| 利辛县| 聂荣县| 沂水县| 三河市| 商河县| 藁城市| 萍乡市| 资阳市| 会宁县| 盖州市|