Maison >développement back-end >tutoriel php >Pourquoi mon code PHP ne parvient-il pas à insérer des images dans une colonne MySQL BLOB ?

Pourquoi mon code PHP ne parvient-il pas à insérer des images dans une colonne MySQL BLOB ?

Mary-Kate Olsen
Mary-Kate Olsenoriginal
2024-11-30 09:33:11200parcourir

Why is my PHP code failing to insert images into a MySQL BLOB column?

Insertion de BLOB dans des bases de données MySQL avec PHP : dépannage du stockage d'images

Lorsque vous essayez de stocker une image dans une base de données MySQL, vous pouvez rencontrer des problèmes si la requête fournie ne parvient pas à enregistrer correctement les données. Examinons le problème et explorons les solutions potentielles.

Problème :

Étant donné la structure de table fournie avec les colonnes ImageId (entier) et Image (longblob), la requête suivante a été utilisé :

$sql = "INSERT INTO ImageStore(ImageId,Image)               
VALUES('$this->image_id','file_get_contents($tmp_image)')";

Malgré l'obtention du résultat attendu de file_get_contents ($tmp_image) lors de l'impression de sa valeur, les données ne sont pas stockées dans la base de données.

Solutions :

Solution 1 : Interpolation variable

La requête que vous avez construite est sensible à un piège PHP courant. Lorsque vous intégrez une variable file_get_contents($tmp_image) dans une chaîne entre guillemets, PHP n'exécutera pas automatiquement la fonction. Au lieu de cela, il le traitera comme une chaîne littérale, écrivant ainsi "file_get_contents($tmp_image)" dans la base de données plutôt que sa valeur renvoyée.

Pour concaténer correctement le résultat de file_get_contents($tmp_image), vous devez quittez la chaîne entre guillemets :

$sql = "INSERT INTO ImageStore(ImageId,Image)
        VALUES('$this->image_id','" . file_get_contents($tmp_image) . "')";

Solution 2 : Désinfection

Si les données binaires contiennent des guillemets simples ('), la requête deviendra invalide. Pour éviter cela, nettoyez les données à l'aide de mysql_escape_string avant de les insérer :

$sql = "INSERT INTO ImageStore(ImageId,Image)
        VALUES('$this->image_id','" . mysql_escape_string(file_get_contents($tmp_image)) . "')";

Solution 3 : Stockage alternatif

Le stockage de données binaires volumineuses (BLOB) dans des bases de données relationnelles peut être inefficace. Envisagez des options de stockage alternatives telles que des fichiers séparés ou des services de stockage cloud conçus pour la gestion des données binaires.

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