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