Warning: file_get_contents(/data/phpspider/zhask/data//catemap/8/mysql/68.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
如何在MySQL中上传图片PHP和插入路径?_Php_Mysql - Fatal编程技术网

如何在MySQL中上传图片PHP和插入路径?

如何在MySQL中上传图片PHP和插入路径?,php,mysql,Php,Mysql,我想在MySQL表中包含一个图像的路径。图像路径通过插入“文件”文本字段的值进入表中(浏览类交易之一)。因此,输入的值类似于:image001.jpg。但我似乎无法使用该值将图像放入html页面。如果它很好地放在桌子上,为什么我不能把它拿出来 我上传了一张图片,但我不知道它去了哪里。因为当我通过PhpMyadmin检查图像字段时,在该字段中并没有输入值 表架构 CREATE TABLE employee_details ( emp_image varchar(255), empl

我想在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>
您只需使用以下方法移动文件:

move_uploaded_file($_FILES['uploaded_file']['tmp_name'], $image_dir. $_FILES['uploaded_file']['name']);
你的图像的完整路径是

$image = $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', 
    ...
)";
第一:只存储文件名,并使用
$\u服务器['DOCUMENT\u 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]')";
并确保图像已成功上载到默认图像目录/路径

更新


我还建议您使用
mysqli.*
PDO
并使用
prepare()
方法/函数来防止sql注入。

如果上载图像,它首先会保存在临时路径中。您必须将其移动到最终目录,否则它将在脚本执行后消失。基本上是这样的:

如果您有一个带有一些表单字段(文本、复选框、文本区域等)和文件字段(
)的表单,则所有“普通”字段都可以通过
$\u POST
数组访问。但是,可以在
$\u FILES
数组中访问文件(另请参见)

现在,当您收到POST请求时,上载的文件将存储在临时目录中。如果您不执行任何操作,它将在脚本执行后再次被删除。所以你需要打电话给警察。例如:

$final_save_dir = '/path/to/images/dir/';
move_uploaded_file($_FILES['uploaded_file']['tmp_name'], $final_save_dir . $_FILES['uploaded_file']['name']);
你的图像的完整路径是

$image = $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的评论。您的脚本非常不安全。

在此处发布一些代码。。然后您得到了一些解决方案。显示您的表并查询与将文件上载到特定路径相比,只在数据库中设置文件名/路径是不同的。您必须同时执行这两项操作。确保您的文件已上载,然后您应该检查是否有上载的图像tb表中的路径。可以在此处找到简单的上载教程:首先,请找出我的错误。它们在我的代码中有错误吗?请注意,文件上载不是存储在
$\u POST
数组中,而是存储在
$\u文件
数组中。是,谢谢你指出这一点,但是你可以将它们存储在变量中并存储到数据库中。你在开玩笑吗?你真的想将$_POST中的原始数据插入数据库吗?Ivan我是php新手,在这个问题上我不是开玩笑的。是的,我选择这个方法。如果我错了,请指导我。检查我的更新。我包括“如何上传”和“如何存储”。这个问题问的是:如何在MySQL中插入图像路径?“与如何在MySQL中上传图像和存储路径不同?很抱歉,我是新来的,不知道如何正确提问。你是对的,现在我清楚地知道,我想问的是如何在MySQL中上传图像和存储路径。。。请就这个问题提出一些看法。