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
Libérer: 2024-11-30 09:33:11
original
188 Les gens l'ont consulté

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)')";
Copier après la connexion

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) . "')";
Copier après la connexion

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)) . "')";
Copier après la connexion

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!

source:php.cn
Déclaration de ce site Web
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
Derniers articles par auteur
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal