当先锋百科网

首页 1 2 3 4 5 6 7

网页开发中,我们经常需要上传图片到服务器,并将图片信息保存到数据库中。PHP是一种常用的后台语言,可以方便地处理图片上传、存储和数据库操作。本文将介绍如何使用PHP将网页上传的图片保存到MySQL数据库中。

网页与php上传到mysql图片

首先,我们需要在HTML表单中添加一个文件上传的input标签,用于选择图片文件:


<form action="upload.php" method="post" enctype="multipart/form-data">
  <input type="file" name="image" id="image">
  <input type="submit" value="Upload">
</form>

接着,在处理上传的PHP文件中,我们需要将上传的文件保存到服务器上。可以使用move_uploaded_file函数将临时文件保存到指定的目录中:


if(isset($_FILES['image'])){
  $image = $_FILES['image'];
  $filename = time() . '-' . $image['name'];
  $destination = 'uploads/' . $filename;
  move_uploaded_file($image['tmp_name'], $destination);
}

其中,$image变量保存了上传的文件信息,$filename通过时间戳和原始文件名生成一个唯一的文件名,$destination指定文件保存的目录。move_uploaded_file函数将临时文件移动到指定目录中。

接下来,我们需要将图片信息保存到数据库中。我们可以使用MySQL的BLOB类型保存图片数据。下面是保存图片数据到数据库的代码:


if(isset($_FILES['image'])){
  // 保存图片到服务器
  $image = $_FILES['image'];
  $filename = time() . '-' . $image['name'];
  $destination = 'uploads/' . $filename;
  move_uploaded_file($image['tmp_name'], $destination);

  // 保存图片信息到数据库
  $db = mysqli_connect('localhost', 'root', 'password', 'test');
  $data = file_get_contents($destination);
  $stmt = $db->prepare('INSERT INTO images (name, mime, size, data) VALUES (?, ?, ?, ?)');
  $stmt->bind_param('ssis', $filename, $image['type'], $image['size'], $data);
  $stmt->execute();
}

其中,$db变量保存了数据库连接对象,$data使用file_get_contents函数读取文件内容,然后将图片数据保存到BLOB类型的data字段中。

在上面的代码中,我们使用了MySQL的预处理语句来绑定参数,确保输入的数据是安全的,避免了SQL注入攻击。

现在,我们已经成功地将网页上传的图片保存到了MySQL数据库中,可以在需要的时候从数据库中读取并显示出来。