存储图像名称

时间:2016-02-16 12:56:24

标签: php mysql image-upload

我目前正在将图像直接存储到数据库中。我了解到将图像存储到数据库并不是一个好主意,而是应该将图像上传到目录并将文件名插入数据库。这就是我将图像上传到目录的方式。

<?php

$newImageSubmitted = isset( $_POST['new-image'] );
if ( $newImageSubmitted ) 
{
    $output = upload();
}
return $output;
/function upload()
{
include_once "Uploader.class.php";

$uploader = new Uploader( "image-data" );
$uploader->saveIn("img");
$fileUploaded = $uploader->save();
if ( $fileUploaded )
 {

$out = "<span class='rare'>Image uploaded success!!!..</span>";

} else {
$out = "something went wrong";
}
return $out;
}

我的表格如下:

<form method='post' action='upload.php' enctype='multipart/form-data' >
<label>Find a jpg image to upload</label>
<input type='file' name='image-data' accept='image/jpg'/>
<input type='submit' value='upload' name='new-image' />
</form>

现在我如何将图像名称存储到数据库??:

$db = new mysqli("localhost", "root","","rec");

if ($db->connect_error) {
    die("Connection failed this is the error: " . $db->connect_error);
}

$stmt = $db->prepare("INSERT INTO records (image) VALUES (?)");
if($stmt)
{
    $stmt>bind_param("b",$newImageSubmitted);
    $stmt->execute();
    echo"<center>Image path stored.</center>";
}

如果需要,这里是uploader.class.php。

<?php

class Uploader {
private $filename;
private $fileData;
private $destination;

public function __construct( $key ) {
$this->filename = $_FILES[$key]['name'];
$this->fileData = $_FILES[$key]['tmp_name'];
}
public function saveIn( $folder ) {
$this->destination = $folder;
}
public function save(){
$folderIsWriteAble = is_writable( $this->destination );
if( $folderIsWriteAble ){
$name = "$this->destination/$this->filename";
$succes = move_uploaded_file( $this->fileData, $name );
} else {
trigger_error("cannot write to $this->destination");
$succes = false;
}
return $succes;
}
}

2 个答案:

答案 0 :(得分:0)

进行像

这样的小调整
public function save(){
$folderIsWriteAble = is_writable( $this->destination );
if( $folderIsWriteAble ){
 $name = "$this->destination/$this->filename";
// new code
 if($succes = move_uploaded_file( $this->fileData, $name )){
return $name; 
}     
} else {
trigger_error("cannot write to $this->destination");
$succes = false;
}
return $succes;
}

然后在调用页面中进行小调整,如: -

$fileUploaded = $uploader->save();
if ( $fileUploaded )
 {
   $insert="Insert into images (img_filename) values (?)";
   $stmt=$con->prepare($insert);
   $stmt->bind_param('s', $fileUploaded);
   $stmt->execute();

$out = "<span class='rare'>Image uploaded success!!!..</span>";

} else {
$out = "something went wrong";
}

答案 1 :(得分:0)

在上一段代码中,将$newImageSubmitted变量填入上传图片的路径。

来自您的第一部分的

$fileUploaded似乎是一个对象,可能提供getFilename方法或类似的东西。

为了帮助您,您必须提供更多代码。你的Uploader-Class看起来像什么?

- 更新 -

在save-method中使你的Uploader-Class返回$name

$name = "$this->destination/$this->filename";
$succes = move_uploaded_file( $this->fileData, $name );

如果成功:

return $name;