doumiao0498 2014-05-25 09:55
浏览 174

pdo直接将图像插入数据库 - 始终插入BLOB - 0B

I'm trying to insert the image into mysql database table directly. In my database I'm always getting [BLOB - 0B]. it doesn't insert images into table. I didn't get any error too. I'm confused..

PHP

ini_set('display_startup_errors',1);
    ini_set('display_errors',1);
    error_reporting(-1);

    include('config.php');
     if (isset($_FILES['image']) && $_FILES['image']['size'] > 0) 
      { 
          $tmpName  = $_FILES['image']['tmp_name'];  

          $fp = fopen($tmpName, 'r');
          $data = fread($fp, filesize($tmpName));
          $data = addslashes($data);
          fclose($fp);
      } 

      try
        {
            $stmt = $conn->prepare("INSERT INTO images ( picture ) VALUES ( '$data' )");
//          $stmt->bindParam(1, $data, PDO::PARAM_LOB);
            $conn->errorInfo();
            $stmt->execute();
        }
        catch(PDOException $e)
        {
            'Error : ' .$e->getMessage();
        }

HTML

<form action="upload.php" method="post">
<input id="image" name="image" type="file" />
<input type="submit" value="Upload" />
</form>
  • 写回答

1条回答 默认 最新

  • dongyun65343 2014-05-25 10:01
    关注

    You almost got it, you want PDO::PARAM_LOB to be a file pointer which you created above, not the result of reading the fp

    if (isset($_FILES['image']) && $_FILES['image']['size'] > 0) 
    { 
       $tmpName  = $_FILES['image']['tmp_name'];  
    
       $fp = fopen($tmpName, 'rb'); // read binary
    } 
    
    try
    {
       $stmt = $conn->prepare("INSERT INTO images ( picture ) VALUES ( ? )");
       $stmt->bindParam(1, $fp, PDO::PARAM_LOB);
       $conn->errorInfo();
       $stmt->execute();
    }
    catch(PDOException $e)
    {
       'Error : ' .$e->getMessage();
    }
    
    评论

报告相同问题?

悬赏问题

  • ¥15 r语言神经网络自变量重要性分析
  • ¥15 基于双目测规则物体尺寸
  • ¥15 wegame打不开英雄联盟
  • ¥15 公司的电脑,win10系统自带远程协助,访问家里个人电脑,提示出现内部错误,各种常规的设置都已经尝试,感觉公司对此功能进行了限制(我们是集团公司)
  • ¥15 救!ENVI5.6深度学习初始化模型报错怎么办?
  • ¥30 eclipse开启服务后,网页无法打开
  • ¥30 雷达辐射源信号参考模型
  • ¥15 html+css+js如何实现这样子的效果?
  • ¥15 STM32单片机自主设计
  • ¥15 如何在node.js中或者java中给wav格式的音频编码成sil格式呢