「労働者が自分の仕事をうまくやりたいなら、まず自分の道具を研ぎ澄まさなければなりません。」 - 孔子、「論語。陸霊公」
表紙 > プログラミング > PHP イメージのアップロードが MySQL データベースに挿入できない場合のトラブルシューティング方法

PHP イメージのアップロードが MySQL データベースに挿入できない場合のトラブルシューティング方法

2025 年 1 月 16 日に公開
ブラウズ:127

How to Troubleshoot PHP Image Uploads Failing to Insert into a MySQL Database?

PHP コードを使用して MySQL データベースに画像をアップロードする方法

MySQL データベースへの画像のアップロードは、Web アプリケーションを開発する際の一般的なタスクです。ただし、画像データを効率的に処理できるように PHP コードが正しく構成されていることを確認することが重要です。

問題の説明

開発者は PHP コードで問題を経験しています。画像を MySQL データベースに挿入することを目的としています。このコードはエラー メッセージを生成しませんが、画像データをデータベースに挿入できません。コードのスニペットを以下に示します。

$image = file_get_contents ($_FILES['image']['tmp_name']);
$image_name = $_FILES['image']['name'];
if ($image_query = mysql_query ("insert into product_images values (1,'$image_name',$image )"))
{
  echo $current_id;
 //echo 'Successfull';
}
else
{
  echo mysql_error();
}

解決策

分析の結果、コード内に次の問題が特定されました:

  • SQL テーブル構成: 画像を保存するために指定された MySQL テーブルの列が、バイナリを収容できる BLOB 型であることを確認してください。 data.
  • MySQL 関数の使用法: 最新の PHP コードでは、非推奨の mysql 関数の代わりに、データベース インタラクションに PDO または MySQLi 関数を使用する必要があります。
  • フォーム構造: コード スニペットで提供されている HTML フォームは古いため、次の形式に従う必要があります:
  • 画像エスケープ: 画像データを BLOB として扱うときは、構文エラーを防ぐために mysql_real_escape_string() を使用してエスケープされていることを確認してください。

改訂されたコード

次のコードには、必要なコードが組み込まれています修正:

$image = addslashes(file_get_contents($_FILES['image']['tmp_name']));
$image_name = addslashes($_FILES['image']['name']);
$sql = "INSERT INTO `product_images` (`id`, `image`, `image_name`) VALUES ('1', '{$image}', '{$image_name}')";
if (!mysql_query($sql)) { // Error handling
    echo "Something went wrong! :("; 
}

これらの問題に対処することで、PHP コードは画像を MySQL データベースに正常にアップロードできるようになります。また、パフォーマンスとスケーラビリティの理由から、イメージ ファイルをデータベース内ではなくディスクに保存することを検討することをお勧めします。

最新のチュートリアル もっと>

免責事項: 提供されるすべてのリソースの一部はインターネットからのものです。お客様の著作権またはその他の権利および利益の侵害がある場合は、詳細な理由を説明し、著作権または権利および利益の証拠を提出して、電子メール [email protected] に送信してください。 できるだけ早く対応させていただきます。

Copyright© 2022 湘ICP备2022001581号-3