如何将sql行id传递到类中(PHP)

时间:2014-11-03 16:32:46

标签: php arrays class mysqli parameters

下面的脚本处理表单数据(多个文本字段,单选按钮值和2个文件上载)。我在脚本中有两个sql语句,一个在php类CropAvatar之外,它将文本字段插入到sql,另一个在CropAvatar类中的sql语句将两个文件URL插入到sql中。我似乎无法使两个sql语句同时工作。我不认为我完全掌握了php类的工作方式。

让这两个sql INSERT语句运行的最佳方法是什么?

此外,两个语句都需要插入sql 中的同一行。我猜我需要定义行的id(自动增量)并且'传递'它进入了课堂。令人难以置信的困惑。

这是脚本,提前谢谢你:

<?php
    require('../dbcon.php');
    $title = $_POST['title'];$address = $_POST['address'];$sale_price = $_POST['sale_price'];$lease_price = $_POST['lease_price'];$build_size = $_POST['build_size'];$lot_size = $_POST['lot_size'];$zoning = $_POST['zoning'];$comment = $_POST['comment'];$transaction = $_POST['transaction'];
$sql="INSERT INTO listings ( title, address, lot_size, zoning, build_size, sale_price, lease_price, comment, transaction, date_added)
     VALUES ( '$title', '$address', '$lot_size', '$zoning', '$build_size', '$sale_price', '$lease_price', '$comment', '$transaction', now())";
    mysqli_query($con,$sql);
class CropAvatar {
    private $src;private $data;private $file;private $dst;private $type;private $extension;private $srcDir = '../0images/listimg/orig';private $dstDir = '../0images/listimg/mod';private $msg;

    function __construct($src, $data, $file) {
        $this -> setSrc($src);
        $this -> setData($data);
        $this -> setFile($file);
        $this -> crop($this -> src, $this -> dst, $this -> data);
    }
    private function setSrc($src) {
        if (!empty($src)) {
            $type = exif_imagetype($src);

            if ($type) {
                $this -> src = $src;
                $this -> type = $type;
                $this -> extension = image_type_to_extension($type);
                $this -> setDst();
            }
        }
    }
    private function setData($data) {
        if (!empty($data)) {
            $this -> data = json_decode(stripslashes($data));
        }
    }
    private function setFile($file) {
        $errorCode = $file['error'];
        if ($errorCode === UPLOAD_ERR_OK) {
            $type = exif_imagetype($file['tmp_name']);
            if ($type) {
                $dir = $this -> srcDir;
                if (!file_exists($dir)) {
                    mkdir($dir, 0777);
                }           
                $extension = image_type_to_extension($type);
                $currdate=date('YmdHis');
                $src = $dir . '/' . $currdate . $extension;

                if ($type == IMAGETYPE_GIF || $type == IMAGETYPE_JPEG || $type == IMAGETYPE_PNG) {

                    if (file_exists($src)) {
                        unlink($src);
                    }

    $result = move_uploaded_file($file['tmp_name'], $src);

    $listing_img="http://www.website.com/0images/listimg/mod/" . $currdate . $extension;
    $allowedExtsf = array("pdf");
    $tempf = explode(".", $_FILES["flyer"]["name"]);
    $extensionf = end($tempf);

    if (($_FILES["flyer"]["type"] == "application/pdf")
    && ($_FILES["flyer"]["type"] <2000000000)
    && in_array($extensionf, $allowedExtsf)) 
    {
    $flyername=$_FILES["flyer"]["name"];

    if ($_FILES["flyer"]["error"] > 0) 
    {
    echo "Return Code: " . $_FILES["flyer"]["error"] . "<br>";
    }   
    else 
    {
        if (file_exists("../flyers/" . $_FILES["flyer"]["name"])) 
        {
         echo $_FILES["flyer"]["name"] . " already exists. ";
        }
            else 
            {
            move_uploaded_file($_FILES["flyer"]["tmp_name"],"../flyers/" . $_FILES["flyer"]["name"]);
             }
    }
  $ad_link="http://www.wesbite.com/flyers/" . $_FILES["flyer"]["name"];
  require('../dbcon.php');
  $sql="INSERT INTO listings (listing_img, ad_link)
   VALUES ('$listing_img', '$ad_link',)";
  mysqli_query($con,$sql);mysqli_close($con);
  }
                    if ($result) {
                        $this -> src = $src;$this -> type = $type;$this -> extension = $extension;$this -> setDst();
                    } else {
                         $this -> msg = 'Failed to save file';
                    }
                } else {
                    $this -> msg = 'Please upload image with the following types: JPG, PNG, GIF';
                }
            } else {
                $this -> msg = 'Please upload image file';
            }
        } else {
            $this -> msg = $this -> codeToMessage($errorCode);
        }
    }
private function setDst() {
        $dir = $this -> dstDir;

        if (!file_exists($dir)) {
            mkdir($dir, 0777);
        }

        $this -> dst = $dir . '/' . date('YmdHis') . $this -> extension;
    }
private function crop($src, $dst, $data) {
        if (!empty($src) && !empty($dst) && !empty($data)) {
            switch ($this -> type) {
                case IMAGETYPE_GIF:
                    $src_img = imagecreatefromgif($src);
                    break;
                case IMAGETYPE_JPEG:
                    $src_img = imagecreatefromjpeg($src);
                    break;
                case IMAGETYPE_PNG:
                    $src_img = imagecreatefrompng($src);
                    break;
            }
            if (!$src_img) {
                $this -> msg = "Failed to read the image file";
                return;
            }
            $dst_img = imagecreatetruecolor(220, 220);
            $result = imagecopyresampled($dst_img, $src_img, 0, 0, $data -> x, $data -> y, 220, 220, $data -> width, $data -> height);
            if ($result) {
                switch ($this -> type) {
                    case IMAGETYPE_GIF:
                        $result = imagegif($dst_img, $dst);
                        break;
                    case IMAGETYPE_JPEG:
                        $result = imagejpeg($dst_img, $dst);
                        break;
                    case IMAGETYPE_PNG:
                        $result = imagepng($dst_img, $dst);
                        break;
                }
                if (!$result) {
                    $this -> msg = "Failed to save the cropped image file";
                }
            } else {
                $this -> msg = "Failed to crop the image file";
            }
            imagedestroy($src_img);
            imagedestroy($dst_img);
        }
    }
    private function codeToMessage($code) {
        switch ($code) {
            case UPLOAD_ERR_INI_SIZE:
                $message = 'The uploaded file exceeds the upload_max_filesize directive in php.ini';
                break;
            case UPLOAD_ERR_FORM_SIZE:
                $message = 'The uploaded file exceeds the MAX_FILE_SIZE directive that was specified in the HTML form';
                break;
            case UPLOAD_ERR_PARTIAL:
                $message = 'The uploaded file was only partially uploaded';
                break;
            case UPLOAD_ERR_NO_FILE:
                $message = 'No file was uploaded';
                break;
            case UPLOAD_ERR_NO_TMP_DIR:
                $message = 'Missing a temporary folder';
                break;
            case UPLOAD_ERR_CANT_WRITE:
                $message = 'Failed to write file to disk';
                break;
            case UPLOAD_ERR_EXTENSION:
                $message = 'File upload stopped by extension';
                break;
            default:
                $message = 'Unknown upload error';
        }
        return $message;
    }
    public function getResult() {
        return !empty($this -> data) ? $this -> dst : $this -> src;
    }
    public function getMsg() {
        return $this -> msg;
    }
}
$crop = new CropAvatar($_POST['avatar_src'], $_POST['avatar_data'], $_FILES['avatar_file']);
$response = array(
    'state'  => 200,
    'message' => $crop -> getMsg(),
    'result' => $crop -> getResult()
);

echo json_encode($response);
?>

0 个答案:

没有答案