一 为了测试图片上传功能, 把图片路径保存到数据库, 我们得先新建个测试表test_img
.
CREATE TABLE test_img ( id int(4) UNSIGNED NOT NULL AUTO_INCREMENT, path varchar(100) default NULL, upload_time timestamp default CURRENT_TIMESTAMP, PRIMARY KEY(id) )engine=myisam DEFAULT charset=utf8
sql 命令: 插入表中时生成一个唯一的数字, 比如测试数据多了, id 是不停地自增, 如果要把 id 回归到 1, 可以尝试以下命令.
alter table test_img auto_increment = 1
二 新建img.html
文件用于选择上传图片
<!DOCTYPE html><html lang="utf-8"><head> <meta charset="UTF-8"> <title>图片上传</title></head><body><form action="img.php" method="post" enctype="multipart/form-data"> 选择上传的图片: <input type="file" name="file" accept="image/*"> <br><br> <input type="submit" value="上传"></form>
<form>
标签中的enctype
控制着是否编码发送表单数据, 默认是application/x-www-form-urlencoded
, 即在发送前编码所有字符.
<input>
标签中的accept
限制上传格式.
三 新建img.php
用于接受处理图片
$_FILES
获取图片文件, 将具体文件名字添加到数据表test_img
中,move_uploaded_file
将图片文件存储到目标文件夹下,iconv
作字符编码处理, 防止有中文命名的图片上传后出现乱码的情况.
<?php header("Content-Type: text/html;charset=utf-8"); $conn = new mysqli('localhost', 'root', '', 'test'); if (!$conn) { die("Connection failed: " . mysqli_connect_error()); } $destination = '../upload/image/'; $file = $_FILES['file']; // 获取上传的图片 $filename = $file['name']; $insert = "INSERT INTO test_img (path) VALUES ('$filename')"; $test = move_uploaded_file($file['tmp_name'], $destination . iconv("UTF-8", "gb2312", $filename)); if ($insert && $test) { $conn->query($insert); } else { echo '上传失败' . '<br>'; } $select = 'SELECT path FROM test_img'; $result = $conn->query($select); while ($row = $result->fetch_assoc()) { echo "<img src=" . $destination . $row['path'] . ">"; }
print_r( $_FILES[‘file’]); // 输出接受到的上传图片得到如下信息
上传图片成功后, 通过数据表图片信息匹配upload/image
下的图片循环显示出来, 效果如下.
四 写到最后
以上只是分享个 php 粗糙版上传图片的功能实现, 有些细节你大可自己尝试修改完善, 要想学好必须通过亲自动手领悟, 云学习只能撸个皮毛而已, 如果我的分享能让你有点启发的话,不如点个赞激励一下我, 当然不给也行, 我也会自我驱动学习的啦~
感谢大家的阅读,希望大家有所收获
本文转自:https://blog.csdn.net/Zhang17_617/article/details/86812795
推荐教程:《php教程》
文章题目:手把手教你用php实现图片上传功能
文章路径:https://www.cdcxhl.com/article44/cjsdhe.html
成都网站建设公司_创新互联,为您提供搜索引擎优化、自适应网站、商城网站、响应式网站、网站设计公司、手机网站建设
声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联