在您的评论中,您询问如何将数据上传和存储到 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'];
有几种方法可以存储数据库的路径:
第一:是只存储文件名并使用 PHP 连接图像的$_SERVER['DOCUMENT_ROOT']
路径和您的默认图像路径,例如:
$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_*
orPDO
并使用prepare()
方法 /function 来防止 sql 注入。