通常我会为此简化我的代码,或者只显示给我带来麻烦的部分。但是在这种情况下,我不知道出了什么问题,所以我把整个事情粘在了。抱歉。
好的以下脚本获取ajax发送的值并将它们上传到sql数据库中。 完成后,它将图像从文件夹移动到另一个文件夹。
整个脚本工作正常,做了它应该做的事情,除了'move_uploaded_file'位。所以它正确地执行了sql部分,并且所有会话名称,字符串编辑等都是正确的。
我已经回应了脚本生成的文件的名称,并且它们是正确的。文件夹也可以读写。并且等待移动的文件存在于文件夹中。
我错过了什么?为什么move_uploaded_file不起作用?在此先感谢所有。
- 将move_uploaded_file()更改为rename(),仍然无效 -
<?php
session_start();
unset($_SESSION['reference']);
$name = $_GET['name'];
$category = $_GET['category'];
$subCategory = $_GET['subCategory'];
$date = $_GET['date'];
$address = $_GET['address'];
$city = $_GET['city'];
$state = $_GET['state'];
$host = $_GET['host'];
$info = $_GET['info'];
$adder = $_SESSION['user'];
//turn into array
$array = array();
$array[0]=$name;
$array[1]=$category;
$array[2]=$subCategory;
$array[3]=$date;
$array[4]=$address;
$array[5]=$city;
$array[6]=$state;
$array[7]=$host;
$array[9]=$info;
$array[11]=$adder;
try {
$con = new PDO('mysql:host=localhost;dbname=test');
//$con->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
$refid=$con->prepare(" SELECT MAX(id) FROM createX ");
$refid->execute();
$id = $refid->fetchColumn();
$id=$id+1;
$newDate = str_replace('-', '', $date);
$reference = $id.$newDate;
$array[10]=$reference;
$array[8] = $_SESSION['imagePath'].$reference.'.'.$_SESSION['imageExt'];
$insert = $con->prepare(" INSERT INTO createX
(name,category,subCategory,date,address,city,state,host,imagePath,info,ref,adder)
VALUES (?,?,?,?,?,?,?,?,?,?,?,?) ");
$insert->execute($array);
rename( '../tempUploads/'.$_SESSION['imagePath'].$_SESSION['imageExt'] ,
'../uploads/'.$_SESSION['imagePath'].$reference.'.'.$_SESSION['imageExt'] );
}
catch(PDOException $e) { //try
echo 'error';
//echo 'ERROR: ' . $e->getMessage();
}
$_SESSION['reference'] = $reference;
unset($array);
session_write_close();
?>
答案 0 :(得分:4)
move_uploaded_file()
仅适用于通过POST上传的文件。源文件名应来自$_FILES['xxx']['tmp_name']
,并相对于用于临时保存已发布文件的目录进行解释。
如果您想移动其他文件,请使用rename()
。