通过PHP上传OO Profile图片

时间:2016-01-04 12:54:29

标签: php sql

我使用面向对象的技术开发了一个注册表单,它工作正常,除非我尝试并包含文件上传,以便用户可以将图片保存在数据库中。

在我的数据库中,我使用BLOB格式并使用 file_get_contents 来检索上传的文件。

我之前有$profilepic = $_POST['photo'];这就是$_POST['photo']仍在第二个if语句中的原因。

我有点困惑使用什么格式,因为我没有做很多面向对象。

提前致谢

<center>
<?php
session_start();
include 'registrationform.php';
include 'connection.php';

if (isset($_POST['regsubmit'])) 
    {
    $firstname = $_POST['firstname'];
    $firstname = ucfirst($firstname);
    $lastname = $_POST['lastname'];
    $lastname = ucfirst($lastname);
    $user = $_POST['username'];
    $user = ucfirst($user);
    $pass = $_POST['password'];
    $spass = $_POST['secondpassword'];
    $profilepic = file_get_contents($_FILES['photo']['tmp_name']);

    if($_POST['firstname'] && $_POST['lastname'] && $_POST['photo'] && $_POST['username'] && $_POST['password'] && $_POST['secondpassword'])
    {
    if ($spass == $pass)
    {
    $query = "INSERT INTO users (firstname, lastname, photo, username, password) VALUES(?, ?, ?, ?, ?)";
    $statement = $connection->prepare($query);
    $statement->bind_param('ssbss', $firstname, $lastname, $profilepic, $user, $pass);

    if($statement->execute()){
        print 'Success!'; 
        }else  
        {
        die('Error : ('. $mysqli->errno .') '. $mysqli->error);
        }
        $statement->close();
        }
        else
        {
           print 'The passwords do not match!';
        }
    }
    else
    {
        print 'Enter all fields please';
    }
    }
?>
</center>

1 个答案:

答案 0 :(得分:2)

您可以使用move_uploaded_file()将上传的图像移动到文件夹中,并将图像名称存储在数据库中 您可以获得如下图像名称:

$image_name = $_FILES["photo"]["name"];

要显示图像,您可以检索图像名称 然后在html中,您可以显示如下图像:
<img src="YOUR_IMAGE_FOLDER_PATH/".$IMAGE_NAME>

相关问题