Maison >développement back-end >Problème PHP >Explication détaillée de la façon de convertir des données au format json en php

Explication détaillée de la façon de convertir des données au format json en php

PHPz
PHPzoriginal
2023-04-04 17:27:072928parcourir

Avec le développement rapide de la technologie Internet, de plus en plus de sites Web et d'applications utilisent la technologie ajax pour réaliser l'interaction des données avec le serveur. En tant que l'un des formats d'échange de données les plus couramment utilisés, json est devenu le premier choix de nombreux développeurs. Comment convertir des données au format json en php, c'est ce que va présenter cet article.

1. Introduction au format json

json signifie JavaScript Object Notation. Il s'agit d'un format de données léger, facile à lire et à écrire. Il est basé sur un sous-ensemble du langage JavaScript et peut donc être pris en charge par différents langages. Comparé au format XML, le format JSON est plus concis, plus léger et a une vitesse d'analyse plus élevée. Dans les applications Web, json est largement utilisé dans l'interaction des données, telles que les requêtes ajax, les interfaces API, etc.

2. Fonction PHP vers json

En PHP, vous pouvez utiliser la fonction json_encode() pour convertir les données au format json. Cette fonction peut convertir n'importe quel type de données php au format json. Par exemple :

$data = array(
    'name' => 'Tom',
    'age'  => 20,
    'sex'  => 'Male'
);

$json = json_encode($data);
echo $json;

Dans l'exemple ci-dessus, nous définissons un tableau $data, contenant les champs nom, âge et sexe. Utilisez ensuite la fonction json_encode() pour convertir le tableau en chaîne json et stockez-le dans la variable $json. Enfin, la chaîne est générée via l'instruction echo. Le résultat de sortie est le suivant :

{"name":"Tom","age":20,"sex":"Male"}

3. Convertissez le résultat de la requête au format json

Dans les applications pratiques, nous devons généralement convertir les résultats renvoyés par le serveur au format json pour faciliter l'analyse et le traitement par le client. Par exemple, comment convertir les résultats d’une requête de base de données au format json en php ?

Supposons que nous devions interroger les données d'une table étudiante. Les résultats de la requête sont les suivants :

+----+--------+------+------+--------+
| id | name   | age  | sex  | grades |
+----+--------+------+------+--------+
|  1 | Tom    |   20 | Male |     85 |
|  2 | Jack   |   18 | Male |     92 |
|  3 | Alice  |   19 | Female |     78 |
+----+--------+------+------+--------+

Nous pouvons utiliser l'extension mysqli de PHP pour effectuer des opérations de requête, par exemple :

$conn = new mysqli($servername, $username, $password, $dbname);
if ($conn->connect_error) {
    die("Connection failed: " . $conn->connect_error);
}

$sql = "SELECT * FROM students";
$result = $conn->query($sql);

Ensuite, nous devons convertir les résultats de la requête en jsonFormat.Vous pouvez utiliser la méthode suivante:

$rows = array();
while ($row = $result->fetch_assoc()) {
    $rows[] = $row;
}

$json = json_encode($rows);
echo $json;

Parmi eux, $result est l'objet de l'ensemble de résultats de la requête et la méthode fetch_assoc() peut être utilisée pour appeler une ligne de résultats de requête à convertir en un tableau associatif. Ensuite, nous pouvons stocker le tableau associatif de chaque ligne dans le tableau $rows, et enfin convertir le tableau $rows en une chaîne json via la fonction json_encode() et le transmettre au client.

Le résultat de sortie est le suivant :

[
    {
        "id": "1",
        "name": "Tom",
        "age": "20",
        "sex": "Male",
        "grades": "85"
    },
    {
        "id": "2",
        "name": "Jack",
        "age": "18",
        "sex": "Male",
        "grades": "92"
    },
    {
        "id": "3",
        "name": "Alice",
        "age": "19",
        "sex": "Female",
        "grades": "78"
    }
]

4. Notes

Bien que la fonction json_encode() soit une fonction intégrée en PHP, vous devez faire attention aux points suivants lorsque vous utilisez cette fonction :

  1. Ceci la fonction doit être prise en charge par PHP5 ou supérieur ;
  2. Si votre chaîne json contient des caractères chinois, elle ne s'affichera pas correctement. Cela peut être résolu en ajoutant le paramètre JSON_UNESCAPED_UNICODE.
  3. Si vos données comportent des caractères spéciaux tels que des sauts de ligne et des tabulations, vous devez utiliser le paramètre JSON_PRETTY_PRINT pour embellir le format json.

5. Résumé

php est un langage de script côté serveur très populaire pendant le processus d'interaction des données, il est plus pratique d'utiliser le format json pour transmettre des données. Que vous obteniez des données de la base de données ou que vous receviez une demande client, vous pouvez utiliser la fonction json_encode() pour convertir les données au format json afin de faciliter l'analyse et le traitement du client. Dans les applications, nous devons prêter attention à des problèmes tels que le paramétrage du jeu de caractères de sortie et l'échappement des caractères spéciaux pour garantir la fiabilité et l'exactitude des données.

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn