在完成上传过程后,如何从uploadify检索上传的文件详细信息。
我想在上传的文件中执行一个过程。 但是当我使用uploadify时,它只是通过我自定义的uploadify.php将文件上传到某个位置。 我希望这个uploadify进程在完成之后重定向到一个页面,其中包含文件的详细信息,例如文件名和目标位置,我将对上传的文件进行第二次操作
更新
这就是我现在的代码
<style type="text/css">
body {
font: 0.8em/1.6em Arial, Helvetica, sans-serif;
}
fieldset {
width: 500px;
}
#sample {
display:table;
}
#sampleFile {
float: left;
display:table-cell;
margin-right: 15px;
}
#download {
margin-top: 15px;
display: table;
}
.dlImage {
display: table-cell;
float: left;
margin-right: 10px;
}
.dlText {
float: left;
display: table-cell;
}
.fileDetails {
color: red;
}
.releaseDate{
margin-top: -3px;
color: gray;
}
</style>
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8" />
<title>Uploadify scriptData Sample</title>
<link rel="stylesheet" href="uploadify/uploadify.css" type="text/css" />
<script type="text/javascript" src="js/jquery-1.3.2.min.js"></script>
<script type="text/javascript" src="js/jquery.uploadify.js"></script>
<script type="text/javascript">
$(document).ready(function() {
$("#fileUpload").fileUpload({
'uploader': 'uploadify/uploader.swf',
'cancelImg': 'uploadify/cancel.png',
'script': 'uploadify/upload.php',
'folder': 'files',
'multi': false,
'displayData': 'speed',
'onComplete' : function(event, queueID, fileObj, reponse, data) {
location.href="complete.php";
}
});
});
</script>
</head>
<body>
<div id="sample">
<div id="sampleFile">
<fieldset style="border: 1px solid #CDCDCD; padding: 8px; padding-bottom:0px; margin: 8px 0">
<legend><strong>Sélectionner l'image à imprimer :</strong></legend>
<div id="fileUpload">You have a problem with your javascript</div>
<a href="javascript:$('#fileUpload').fileUploadStart()">Start Upload</a> <p></p>
</fieldset>
</div>
</body>
</html>
在第二页上我想回显上传的文件名 我在第二页中有完整的.php
<?php
print_r($_FILES);
echo $_FILES['type'];
echo $_FILES['tmp_name'];
echo $_FILES['name'];
echo $_FILES['size'];
?>
答案 0 :(得分:5)
您是否知道filename
,filpath
可以在onComplete
事件中获取,如下所示: -
onComplete: function(event, queueID, fileObj, reponse, data)
{
alert fileObj.name; //The name of the uploaded file
alert fileObj.filePath; //The path on the server to the uploaded file
location.href= "complete.php?filename="+fileObj.name+"&filepath="+fileObj.filePath; //Here you can do a javascript redirect
}
查看文档以获取更多详细信息http://www.uploadify.com/documentation/events/oncomplete-2/
您在寻找这些价值观吗?如果不让我知道
更新
根据您的问题更新,您有2个选项。
在uploadify.php中上传文件后执行“some process”。您可以看到uploadify插件附带的文件uploadify.php
。你有$_FILES['Filedata']
数组包含所有文件信息。你可以在这里进行后期处理(通过更好地调用函数而不是在uploadify的核心代码中编写大量代码)
$ _FILES ['Filedata'] ['name'] //文件名
或者就像我说的那样,获取onComplete
事件中的文件名和路径。然后通过这些这样的参数: -
location.href= "complete.php?filename="+fileObj.name+"&filepath="+fileObj.filePath;
我认为这更好。您可以发送ajax请求来执行整个过程(文件上载+您的“某个过程”),而无需再次加载页面。
使用这些参数在onComplete
事件中写一个$.post()请求并发布到“complete.php”
在onComplete
内获取默认情况下不可用的参数
您必须使用response
中提供的onComplete
参数
我在uploadify版本2.1.0上工作,所以我的解决方案肯定会在该版本上运行。
如果您只想要一个参数,则可以在uploadify.php
结束时回显该参数
我做了以下事情: -
在我的uploadify.php
已更改(这是在原始uploadify.php中): -
move_uploaded_file($tempFile,$targetFile);
echo "1";
到此: -
move_uploaded_file($tempFile,$targetFile);
echo $tempFile;
然后在onComplete
事件内部发生爆炸 -
var tmpName = reponse;
但是,如果你想在onComplete
中获得多个参数,这是我可以给出的一个技巧(这不是一个好方法,但我无法通过任何其他方式返回多个参数 - 我试过返回json数组等。): -
move_uploaded_file($tempFile,$targetFile);
echo $param1.'%%__%%'.$param2;
然后在onComplete
事件内部发生爆炸 -
var paramsArray = explode('%%__%%',reponse);
param1 = paramsArray[0];
param2 = paramsArray[1];
答案 1 :(得分:0)
您可以通过以下方式回显来获取上传文件的所有详细信息;
print_r($_FIELS);
或者您可以echo
上传文件的所有字段。
echo $_FIELS['type'];
echo $_FIELS['tmp_name'];
echo $_FIELS['name'];
echo $_FIELS['size'];
如果我理解你想说的话,我是对的。但如果你搜索其他任何东西,请发表评论。
感谢。