簡體   English   中英

如何上傳圖片PHP並在MySQL中插入路徑?

[英]How to upload image PHP and insert path in MySQL?

我想在我的MySQL表中包含圖像的路徑。 通過插入“文件”文本字段的值(這些瀏覽類型的交易之一),圖像路徑進入表。 因此,輸入的值類似於: image001.jpg 但是我似乎無法使用該值將圖像放入html頁面。 如果可以放到桌子上,為什么我不能拿出來呢?

我上傳了圖片,但不知道它去了哪里。 因為當我通過PhpMyadmin檢查圖像字段時沒有輸入任何值。

表架構

CREATE TABLE employee_details
(
    emp_image varchar(255),
    employee_name varchar(50),
    employee_address varchar(50),
    employee_designation varchar(50),
    employee_salary int(),
);

詢問

$sql="
    INSERT INTO employee_detail( 
        emp_image, 
        employee_name, 
        employee_address,
        employee_contact, 
        employee_designation, 
        employee_salary
    ) 
    VALUES( 
        '$_POST[emp_image]', 
        '$_POST[employee_name]',
        '$_POST[employee_address]', 
        '$_POST[employee_contact]',
        '$_POST[employee_designation]',
        '$_POST[employee_salary]'
    )";

在您的評論中,您詢問如何將數據上傳和存儲到mysql。 所以這里是:

要獲取文件,您應該在html中有一個腳本,如下所示:

<html>
<body>

     <form action="upload_file.php" method="post" enctype="multipart/form-data">
        <label for="file">Filename:</label>
        <input type="file" name="file" id="file"><br>
        <input type="submit" name="submit" value="Submit">
     </form>

</body>
</html>

現在,在POST上,您的PHP文件應如下所示,但請注意,您必須檢查POST上是否存在該文件:

if ($_FILES["file"]["error"] > 0)
  {
  echo "Error: " . $_FILES["file"]["error"] . "<br>";
  }
else
  {
  echo "Upload: " . $_FILES["file"]["name"] . "<br>";
  echo "Type: " . $_FILES["file"]["type"] . "<br>";
  echo "Size: " . ($_FILES["file"]["size"] / 1024) . " kB<br>";
  echo "Stored in: " . $_FILES["file"]["tmp_name"];

  }

由於“存儲在:”部分只是臨時路徑,因此應使用move_uploaded_file()移至“真實”圖像路徑。 假設圖片的真實/默認路徑位於:

$image_dir= '/images/';

您只需要使用以下命令移動文件:

move_uploaded_file($_FILES['uploaded_file']['tmp_name'], $image_dir. $_FILES['uploaded_file']['name']);

而您獲得圖像的完整路徑將是

$image = $final_save_dir . $_FILES['uploaded_file']['name'];

有幾種方法可以存儲數據庫的路徑:

第一個:僅存儲文件名 ,並使用$_SERVER['DOCUMENT_ROOT']和您的默認圖像路徑在PHP中連接圖像的路徑:

$sql="insert into employee_detail( emp_image, employee_name, employee_address,
    employee_contact, employee_designation, employee_salary) 
values( '$image', '$_POST[employee_name]', '$_POST[employee_address]', '$_POST[employee_contact]',
    '$_POST[employee_designation]','$_POST[employee_salary]')";

第二:是存儲完整路徑,如:

$sql="insert into employee_detail( emp_image, employee_name, employee_address,
    employee_contact, employee_designation, employee_salary) 
values( '".$_SERVER['DOCUMENT_ROOT']."\\images\\".$image."', '$_POST[employee_name]', '$_POST[employee_address]', '$_POST[employee_contact]',
    '$_POST[employee_designation]','$_POST[employee_salary]')";

我建議使用這種方法,其中您將輸入部分路徑 (不包含根目錄),以便以后在部署它時不會遇到問題:

$sql="insert into employee_detail( emp_image, employee_name, employee_address,
    employee_contact, employee_designation, employee_salary) 
values( 'images\\".$image."', '$_POST[employee_name]', '$_POST[employee_address]', '$_POST[employee_contact]',
    '$_POST[employee_designation]','$_POST[employee_salary]')";

並確保將圖像成功上傳到該默認圖像dir / path

更新

我還建議您使用mysqli_*PDO並使用prepare()方法/ function防止sql注入。

如果上傳圖像,則圖像首先會保存在臨時路徑中。 您必須將其移至最終目錄,否則腳本執行后將消失。 基本上會發生以下情況:

如果您的表單中包含某些表單字段(文本,復選框,文本區域等)和文件字段( <input type="file" name="uploaded_file" /> ),則所有“普通”字段都可以通過$_POST數組。 但是,可以在$_FILES數組中訪問文件(另請參見有關文件上傳手冊頁 )。

現在,當您收到POST請求時,上傳的文件將存儲在您的臨時目錄中。 如果您不執行任何操作,則腳本執行后將再次將其刪除。 因此,您需要調用move_uploaded_file()函數 例:

$final_save_dir = '/path/to/images/dir/';
move_uploaded_file($_FILES['uploaded_file']['tmp_name'], $final_save_dir . $_FILES['uploaded_file']['name']);

而您獲得圖像的完整路徑將是

$image_full_path = $final_save_dir . $_FILES['uploaded_file']['name'];

該路徑可以保存在您的數據庫中:

$sql="
INSERT INTO employee_detail( 
    emp_image, 
    ...
) 
VALUES( 
    '$image_full_path', 
    ...
)";

重要提示:請注意@brewal的評論。 這樣,您的腳本非常不安全。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM