PHP uploads images to database and displays them

藏色散人
Release: 2023-04-08 06:28:02
forward
5462 people have browsed it

PHP uploads pictures to the database and displays them

1. Create a data table

CREATE TABLE ccs_image (
  id int(4) unsigned NOT NULL auto_increment,
  description varchar(250) default NULL,
  bin_data longblob,
  filename varchar(50) default NULL,
  filesize varchar(50) default NULL,
  filetype varchar(50) default NULL,
  PRIMARY KEY (id)
)engine=myisam DEFAULT charset=utf8
Copy after login

2. Page used to upload pictures to the server upimage.html

<!doctype html>
<html>
<head>
    <meta charset="UTF-8">
    <meta name="viewport"
          content="width=device-width, user-scalable=no, initial-scale=1.0, maximum-scale=1.0, minimum-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <style type="text/css">
        *{margin: 1%}
    </style>
    <title>Document</title>
</head>
<body>
<form method="post" action="upimage.php" enctype="multipart/form-data">
    描述:
    <input type="text" name="form_description" size="40">
    <input type="hidden" name="MAX_FILE_SIZE" value="1000000"> <br>
    上传文件到数据库:
    <input type="file" name="form_data" size="40"><br>
    <input type="submit" name="submit" value="submit">
</form>
</body>
</html>
Copy after login

3. PHP that handles image uploads upimage.php

<?php
if (isset($_POST[&#39;submit&#39;])) {
    $form_description = $_POST[&#39;form_description&#39;];
    $form_data_name = $_FILES[&#39;form_data&#39;][&#39;name&#39;];
    $form_data_size = $_FILES[&#39;form_data&#39;][&#39;size&#39;];
    $form_data_type = $_FILES[&#39;form_data&#39;][&#39;type&#39;];
    $form_data = $_FILES[&#39;form_data&#39;][&#39;tmp_name&#39;];
    
    $dsn = &#39;mysql:dbname=test;host=localhost&#39;;
    $pdo = new PDO($dsn, &#39;root&#39;, &#39;root&#39;);
    $data = addslashes(fread(fopen($form_data, "r"), filesize($form_data)));
    //echo "mysqlPicture=".$data;
    
    $result = $pdo->query("INSERT INTO ccs_image (description,bin_data,filename,filesize,filetype)
                  VALUES (&#39;$form_description&#39;,&#39;$data&#39;,&#39;$form_data_name&#39;,&#39;$form_data_size&#39;,&#39;$form_data_type&#39;)");
    if ($result) {
        echo "图片已存储到数据库";
    } else {
        echo "请求失败,请重试";
Copy after login

Note: Images are stored in the database as binary blobs , like this

4. Display the php getimage.php

<?php
 
    $id =2;// $_GET[&#39;id&#39;]; 为简洁,直接将id写上了,正常应该是通过用户填入的id获取的
    $dsn =&#39;mysql:dbname=test;host=localhost&#39;;
    $pdo = new PDO($dsn,&#39;root&#39;,&#39;root&#39;);
    $query = "select bin_data,filetype from ccs_image where id=2";
    $result = $pdo->query($query);
    $result = $result->fetchAll(2);
//    var_dump($result);
    $data = $result[0][&#39;bin_data&#39;];
    $type = $result[0][&#39;filetype&#39;];
    Header( "Content-type: $type");
    echo $data;
Copy after login

5. Go to the browser to view the uploaded pictures. See There is no problem whether

PHP uploads images to database and displays them

can be displayed, which proves that the image has been stored in the database in binary form

For more PHP related knowledge, please visit PHP tutorial!

The above is the detailed content of PHP uploads images to database and displays them. For more information, please follow other related articles on the PHP Chinese website!

Related labels:
php
source:csdn.net
Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
Popular Tutorials
More>
Latest Downloads
More>
Web Effects
Website Source Code
Website Materials
Front End Template