php - 使用 PHP 将两个/多个图像上传到 MySQL

标签 php mysql

我在解决这个问题时遇到了问题,基本上我有一个包含图像字段(image 和 image2)的表,我正在重复使用代码并且可以正常工作以在提交中上传非图像,但是第二个一个没有上传,当然也没有插入到数据库中。

<form action="../imgs/update_code.php" method="post" enctype="multipart/form-data" id="form1">

<input name="image1" type="file" />
<input name="image2" type="file" />

<input name="id" type="hidden" value="<?php echo $row_Recordset1['id']; ?>" />
<input name="submit" type="submit" value="submit" />
</form>

谁能告诉我是否可以在一次提交中上传不同的图片,或者我需要继续为每个表单上传一张图片(第一个表单上传/插入“image1”,第二个表单更新/上传“image2”)

<?php require_once('../admin/Connections/cnx.php'); ?>
<?php
ob_start();
$tabla='models';
$destino='../models.php';
mysql_connect($server,$user,$pass);
mysql_select_db($db);
function modificar($tabla,$id){
$strupdate='';
foreach($_POST as $k => $v){
if($k!='imageField_x' && $k!='imageField_y' && $k!='image1' && $k!='image2' &&          $k!='foto2' && $k!='foto3' && $k!='Submit'){
$v=(get_magic_quotes_gpc()) ? $v : addslashes($v);
$strupdate.= "$k='$v',";
}}
$strupdate=substr($strupdate,0,(strlen($strupdate)-1));
mysql_query("SET NAMES utf8");
mysql_query("update $tabla set $strupdate where id='$id'");
}
function reemplazaarchivo($archivo,$archivotemp,$tabla,$campoarchivo,$error,$id){
if($archivo!=''){
$qryant=mysql_query("select * from $tabla where id='$id'");
$rowant=mysql_fetch_array($qryant);
@unlink($rowant[$campoarchivo]);
$extension200=end(explode(".",strtolower($archivo)));
if($extension200!='jpg' && $extension200!='gif' && $extension200!='png' &&  $extension200!='doc' && $extension200!='zip' && $extension200!='pdf' && $extension200!='xls' && $extension200!='ppt' && $extension200!='swf'){
eval($error);exit;}
$foto2=md5(time()).$archivo;
copy($archivotemp,$foto2);
@chmod($foto2,0755);
mysql_query("update $tabla set $campoarchivo='$foto2' where id='$id'");
}
}
modificar($tabla,$_POST['id']);
reemplazaarchivo($_FILES['image1']['name'],$_FILES['image1']['tmp_name'],$tabla,'image1','',$_POST['id']);
for($i=1;$i<4;$i++){
reemplazaarchivo($_FILES['image1'.$i]['name'],$_FILES['image1'.$i]  ['tmp_name'],$tabla,'image1'.$i,'',$_POST['id']);
}
header("Location:$destino");
ob_end_flush();
?>

最佳答案

你甚至谷歌? http://php.net/manual/en/features.file-upload.multiple.php

<form action="file-upload.php" method="post" enctype="multipart/form-data">
  Send these files:<br />
  <input name="userfile[]" type="file" /><br />
  <input name="userfile[]" type="file" /><br />
  <input type="submit" value="Send files" />
</form>

此外,您的代码非常不明确且不安全。请查看安全性。

关于php - 使用 PHP 将两个/多个图像上传到 MySQL,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/19298883/

相关文章:

javascript - 如何将带有哈希文件名的已编译 CSS/JS 包含到网页中

php - preg_match 函数中的 RegExp 返回浏览器错误

php - 动态PHP网页保存为PDF

php - 如何获取具有相同 INNER JOIN'ed ID 的所有记录

mysql - 将列(来自其他表)添加到 'most recent notes for each user' 查询 sql

mysql - 如何在 Node.js 中以列名作为变量读出 MySQL 数据库的所有条目

php - 使用 PHP 从格式化日期获取格式字符串

php - 使用 Bash 脚本并行化 PHP 进程?

php - 将文件名作为 post 变量不好吗?

php - 如何在 MySQLi 中为我的数据库创建表