为什么我的blob没有被发送?

时间:2015-01-10 16:05:06

标签: php mysql wordpress gravity-forms-plugin

我是新手,试图编写一个文件上传验证器将图像作为blob发送到MySQL 数据库。该图像取自wordpress <中的重力形式文件上传(表单ID为1)。当我运行以下脚本时,没有blob发送到我的mallampati_images表,但是显示文件格式警报。它还输出此错误:

Warning: file_get_contents(/home/clients/4ceaa5faab208e8af4350138684e6d6d/web/wp-content/uploads/mallampati.png): failed to open stream: No such file or directory in /home/clients/4ceaa5faab208e8af4350138684e6d6d/web/wp-content/themes/twentytwelve/functions.php on line 535

我不明白的是如何格式化文件的链接。我一直在尝试在网上找到的各种方式几个小时,但我不能让它工作。我编辑了下面的代码以返回链接(这是一个正确的绝对链接,似乎......)

剧本:

function testimage($path)
{
   if(!preg_match("/\.(png|jpg|gif)$/",$path,$ext)) return 0;

   $ret = null;
   switch($ext[1])
   {
       case 'png': $ret = @imagecreatefrompng($path); break;
       case 'jpg': $ret = @imagecreatefromjpeg($path); break;
       case 'gif': $ret = @imagecreatefromgif($path); break;
       default: $ret = 0;
   }

   return $ret;
}

add_action("gform_after_submission_1", "input_fields", 10, 3);
function input_fields($entry){
    global $wpdb;

   if (isset($_FILES['input_1'])) {
     $file_url = $entry['1'];
     //$img_blob = file_get_contents($file_url);
     $validate = testimage($file_url);

     $udir = wp_upload_dir();
     $basedir = $udir['basedir'];
     $target=$basedir.'/'.basename($_FILES['input_1']['name']);

     //$try = $_FILES['input_1']['tmp_name'];
     $img_blob = file_get_contents ($target);
     echo "<script type='text/javascript'>alert('value: $target');</script>";
   }

  if(!empty($validate)) {
     echo "<script type='text/javascript'>alert('The file was of the correct format');</script>";

     $SQL = "INSERT INTO mallampati_images (img_blob) VALUES ( $img_blob )";
     $wpdb->query($SQL);
   }
}

1 个答案:

答案 0 :(得分:0)

我终于成功了。

重力形式似乎不像我一直在看的那样处理文件。问题是它导致在SQL查询中使用了不正确的文件路径。

function testimage($path)
{
   if(!preg_match("/\.(png|jpg|gif)$/",$path,$ext)) return 0;

   $ret = null;
   switch($ext[1])
   {
       case 'png': $ret = @imagecreatefrompng($path); break;
       case 'jpg': $ret = @imagecreatefromjpeg($path); break;
       case 'gif': $ret = @imagecreatefromgif($path); break;
       default: $ret = 0;
   }

   return $ret;
}

add_action("gform_after_submission_1", "input_fields", 10, 2);
function input_fields($entry){
    global $wpdb;

    if(isset($entry[1])){
      $valid = testimage($entry[1]);

      if($valid){
        $mpFilePath= $entry[1];
        $blob = file_get_contents($mpFilePath) or die ('cannot read file');
        $blob = mysql_escape_string($blob);
        $SQL = "INSERT INTO mallampati_images (img_blob) VALUES ( '$blob' )";
        $wpdb->query($SQL) or die ('query failed');
      }
      else{
        echo "<script type='text/javascript'>alert('Incorrect file format');</script>";
      }
    }
}