
新手应该知道的php多图片上传的实现
今天在工作中遇到了一个需求:
一个表单实现多个上传图片,类似于QQ空间上传照片的模式。即:可以一次性上传多个图片,但是封面图片只有一个。
最先,最重要的事,在服务器上对文件进行读写操作的时候,一定要看权限,如果没有权限,全是虾扯蛋,为什么这样说,因为全是泪。
首先,前端页面:index.html
<html>
<head><title>多个文件上传表单title>head>
<body>
<style>
form{
margin: 20px;
padding: 10px;
}
#picInput>input{
display: block;
margin: 10px;
} style>
<form action="pic.php" method="post" enctype="multipart/form-data">
<input type="hidden" name="MAX_FILE_SIZE" value="1000000">
<div id="picInput">
上传图片:<input type="file" name='myfile[]'>
div>
<input id="addBtn" type="button" οnclick="addPic1()" value="继续添加图片"><br/><br/>
<input type="submit" value="上传文件">
form>
<script>
function addPic1(){
var addBtn = document.getElementById('addBtn');
var input = document.createElement("input");
input.type = 'file';
input.name = 'myfile[]';
var picInut = document.getElementById('picInput');
picInut.appendChild(input);
if(picInut.children.length == 3){
addBtn.disabled = 'disabled';
}
} script>
body>
html>
知识点:
1.通过JS动态添加input结点和设置属性,当大于3个上传图片的时候就不再给予上传图片的机会了。
2.这里最主要的是input输入框的name值,通过动态的添加数组元素,将所有上传的图片动态添加到数组当中。
后端处理功能
Connection.php
1.读取和存储都需要用到连接数据库,所以可以把它封住一下,养成良好的习惯
<?php
$mysqli = new mysqli('localhost','root','','test');
if (mysqli_connect_errno()){
die('Unable to connect!'). mysqli_connect_error();
}

pic.php处理功能
<?php
require_once 'connection.php';
$file = $_FILES['myfile'];
$name = $file['name'];
$upload_path = "zhouqi666.cn/test/images/";
foreach ($name as $k=>$names){
$type = strtolower(substr($names,strrpos($names,'.')+1));
$allow_type = array('jpg','jpeg','gif','png');
if (!in_array($type,$allow_type)){
unset($name[$k]);
}
}
$str = '';
foreach ($name as $k=>$item){
$type = strtolower(substr($item,strrpos($item,'.')+1));
if (move_uploaded_file($file['tmp_name'][$k],$upload_path.time().$name[$k])){
echo 'success';
}else{
echo 'failed';
}
}
$uid = 1;
$str = substr($str,1);
$sql = "UPDATE upload set pic = '".$str."' WHERE id = ".$uid;
$result = $mysqli->query($sql);
这里我有很多的判断没有写,主要是实现一下功能PHP文件上传,比如文件夹要先建立好,你也可以自己判断,不存在就创建一个文件夹,还有一些其他判断等等。
最关键的地方是,当你不熟悉的时候,要走一步调试一步,看得到的结果是什么。
图片显示功能
<?php
require_once 'connection.php';
$uid = 1;
$sql = "SELECT pic FROM upload WHERE id =".$uid;
$result = $mysqli->query($sql);
$picpath = '';
while ($row = $result->fetch_array()){
$picpath = $row[0];
}
$picpath = explode(',',$picpath)[0];
echo ".$picpath."'>";
?>
感谢大家的阅读,希望大家收益多多。
(编辑:源码门户网)
【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!
|