jquery - 上传表单数据: Why jquery won't send parameters via post?

标签 jquery uploadify

这是我的代码:

$('#file_upload').uploadify({
        'swf'      : 'uploadify.swf',
        'uploader' : 'uploadify.php',
        'onSelect' : function(file) {
            $('#start').removeClass('hidden');
        },
        'method'   : 'post',
        'formData' : {
            'to': $('input#to').val(),
            'from': $('input#from').val(),
            'subject': $('input#subject').val()
        },
        'onQueueComplete' : function(queueData) {
            window.location.replace("index.php?success=uploaded");
        },
        'onUploadSuccess' : function(file, data, response) {
            alert('The file ' + file.name + ' was successfully uploaded with a response of ' + response + ':' + data);
        }
        // Your options here
    });

如您所见,我通过 POST 方法发送三个参数 TO、FROM、SUBJECT。

有服务器脚本

if (!empty($_FILES)) {
$tempFile = $_FILES['Filedata']['tmp_name'];
$targetPath = $_SERVER['DOCUMENT_ROOT'] . $targetFolder;
$targetFile = rtrim($targetPath,'/') . '/' . $_FILES['Filedata']['name'];

// Validate the file type
$fileTypes = array('jpg','jpeg','gif','png'); // File extensions
$fileParts = pathinfo($_FILES['Filedata']['name']);

if (move_uploaded_file($tempFile, $targetFile)) {

    echo $_REQUEST['subject'];
} else {
    echo "Something wrong";
}
}

并回显 $_REQUEST['subject'];什么也不返回 我的错误在哪里?

如果我将 'subject': $('input#subject').val() 更改为 'subject': 'test subject' ,它就可以工作。但我需要从输入发送一个值。我该怎么做?

非常感谢

最佳答案

您在首次实例化 Uploadify 时设置 formData,而不是在提交上传时设置。如果您这样做,您将在加载页面时将 formData 设置为这些字段的值。

相反,使用 onUploadStart 选项在文件上传之前设置 formData...

$('#file_upload').uploadify({
    'swf'      : 'uploadify.swf',
    'uploader' : 'uploadify.php',
    'onSelect' : function(file) {
        $('#start').removeClass('hidden');
    },
    'method'   : 'post',
    'onQueueComplete' : function(queueData) {
        window.location.replace("index.php?success=uploaded");
    },
    'onUploadStart' : function(file) {
        $('#file_upload').uploadify('settings','formData',{
            'to': $('input#to').val(),
            'from': $('input#from').val(),
            'subject': $('input#subject').val()
        });
    }
    'onUploadSuccess' : function(file, data, response) {
        alert('The file ' + file.name + ' was successfully uploaded with a response of ' + response + ':' + data);
    }
    // Your options here
});

关于jquery - 上传表单数据: Why jquery won't send parameters via post?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11276307/

相关文章:

javascript - Firefox 3.6 尝试显示缩略图时崩溃

jQuery live,获取值,uploadify 不行!

javascript - 使用箭头键移动 SVG 元素

javascript - jQuery Accordion - 一次打开一个

javascript - Jquery 将类添加到设备上的元素

javascript - 如何防止正则表达式中的 "*/"被解释为 block 注释?

javascript - 粘贴HTML内容时如何去掉多余的回车

javascript - 使用 Uploadify 时无法触发 onComplete 和 onCompleteAll 事件

asp.net-mvc - 使用 ASP.NET MVC 上传( session 和身份验证)

jquery - 上传和 HTTP 401 挑战。为什么它不能始终如一地工作?