如何用代码实现获取图片上传路径并保存在数据库
时间: 2023-06-04 22:04:07 浏览: 160
?可以使用以下代码实现获取图片上传路径并保存在数据库中:
1. 首先,创建一个HTML表单,其中包含一个文件上传输入:
```html
<form action="upload.php" method="post" enctype="multipart/form-data">
<input type="file" name="fileToUpload" id="fileToUpload">
<input type="submit" value="Upload Image" name="submit">
</form>
```
2. 然后创建一个 PHP 脚本 upload.php,该脚本处理上传文件并将其保存到服务器上的指定目录中:
```php
$target_dir = "uploads/"; // 上传文件保存的目录
$target_file = $target_dir . basename($_FILES["fileToUpload"]["name"]); // 上传文件的完整路径
$imageFileType = strtolower(pathinfo($target_file, PATHINFO_EXTENSION)); // 上传文件的类型(后缀名)
// 检查上传文件是否为图片
if(isset($_POST["submit"])) {
$check = getimagesize($_FILES["fileToUpload"]["tmp_name"]);
if($check !== false) {
echo "File is an image - " . $check["mime"] . ".";
$uploadOk = 1;
} else {
echo "File is not an image.";
$uploadOk = 0;
}
}
// 检查文件是否已经存在
if (file_exists($target_file)) {
echo "Sorry, file already exists.";
$uploadOk = 0;
}
// 限制上传文件的大小
if ($_FILES["fileToUpload"]["size"] > 500000) {
echo "Sorry, your file is too large.";
$uploadOk = 0;
}
// 限制上传文件的类型
if($imageFileType != "jpg" && $imageFileType != "png" && $imageFileType != "jpeg"
&& $imageFileType != "gif" ) {
echo "Sorry, only JPG, JPEG, PNG & GIF files are allowed.";
$uploadOk = 0;
}
// 检查文件是否被成功上传到服务器上的临时文件夹
if ($uploadOk == 0) {
echo "Sorry, your file was not uploaded.";
// 如果一切正常,尝试将文件从临时目录移动到上传目录,并将文件路径存入数据库
} else {
if (move_uploaded_file($_FILES["fileToUpload"]["tmp_name"], $target_file)) {
echo "The file ". basename( $_FILES["fileToUpload"]["name"]). " has been uploaded.";
// 将文件路径存入数据库,这里以mysqli为例,具体的数据库操作方法可能有所不同
$conn = mysqli_connect("localhost", "username", "password", "database");
$sql = "INSERT INTO images (image_path) VALUES ('$target_file')";
mysqli_query($conn, $sql);
} else {
echo "Sorry, there was an error uploading your file.";
}
}
```
其中,`$target_dir` 变量指定上传文件所保存的目录,`$target_file` 变量则保存上传文件的完整路径。 `basename()` 函数用于获取文件名,`strtolower()` 函数用于将文件后缀名转换为小写。上传文件大小的限制、文件类型的限制、文件是否重复以及数据库操作等都可以按照需要进行修改。
阅读全文