plUpload - 未显示服务器端错误


plUpload - Server Side Errors Not Showing

我有一个基于网站的自定义示例的 plupload 实例,除了显示来自服务器端上传脚本(上传.php的错误消息外,它运行良好下载中的示例文件夹)。

显示本地错误消息,例如,如果我尝试上传已受限制的文件类型,则会收到预期的错误消息,但是,服务器端消息只是没有显示。

我知道上传.php文件正在正确触发,因为我的上传已成功处理,并且我已经设置了一个睡眠函数来验证是否正在请求该文件。目前,我只是简单地将行放在上传的顶部.php以帮助调试,只需休眠 10 秒并返回错误消息,这仍然不起作用。

upload.php
    sleep(10);
    die('{"jsonrpc" : "2.0", "error" : {"code": 500, "message": "THIS IS AN ERROR."}, "id" : "id"}');
...(Rest of normal upload.php file)...

正在使用的 JavaScript 包含在下面,你们可以提供的任何帮助将不胜感激,因为我已经在这方面花了太长时间,而且这个问题阻碍了我能够实时推送我的代码。

谢谢

亚历克斯

// Fanart
$(function() {
var fanart_uploader = new plupload.Uploader({
    runtimes : 'html5,flash,html4',
    browse_button : 'fanart_pickfiles',
    container : 'fanart_container',
    drop_element : 'fanart_drop',
    chunk_size : '1mb',
    max_file_size : '8mb',
    url : '/upload.php?gameid=<?= $gameid ?>&arttype=fanart',
    flash_swf_url : '/js/plupload/js/plupload.flash.swf',
    silverlight_xap_url : '/js/plupload/js/plupload.silverlight.xap',
    filters : [
        {title : "Image files", extensions : "jpg,png"},
    ]
});
fanart_uploader.bind('Init', function(up, params) {
    $('#fanart_runtime').html("You are using " + params.runtime);
});
$('#fanart_uploadfiles').click(function(e) {
    fanart_uploader.start();
    e.preventDefault();
});
fanart_uploader.init();
fanart_uploader.bind('FilesAdded', function(up, files) {
    $.each(files, function(i, file) {
        $('#fanart_filelist').append(
            '<div style="padding: 4px; margin: 3px; border: 1px dotted #fff; border-radius: 6px; background-color: #333;" id="' + file.id + '"><img class="tick" src='"<?= $baseurl ?>/images/common/icons/tick_16.png'" style='"display: none; vertical-align: -2px;'" />' +
            file.name + ' <em>(' + plupload.formatSize(file.size) + ')</em> <div style='"margin: auto; margin-top: 3px; width: 200px; height: 20px; border: 1px solid #fff; border-radius: 6px; background-color: #222;'"><div class="progressbar" style='"width: 0px; height: 16px; padding: 2px 0px; background-color: #ccc; border-radius: 6px; text-align: center;'"><b style="font-size: 16px; color: #222;"></b></div></div>' +
        '</div>');
    });
    up.refresh(); // Reposition Flash/Silverlight
});
fanart_uploader.bind('UploadProgress', function(up, file) {
    $('#' + file.id + " b").html(file.percent + "%");
    $('#' + file.id + " .progressbar").css("width", (file.percent * 2));
});
fanart_uploader.bind('Error', function(up, err) {
    $('#fanart_filelist').append("<div>Error: " + err.code +
        ", Message: " + err.message +
        (err.file ? ", File: " + err.file.name : "") +
        "</div>"
    );
    up.refresh(); // Reposition Flash/Silverlight
});
fanart_uploader.bind('FileUploaded', function(up, file) {
    $('#' + file.id + " .tick").show();
});
});

这是您链接到的答案:

NM,回答了我自己的问题...

似乎我的 plUpload 实例减轻了服务器响应,这是一个 JSON 字符串到一个 JS 对象中,可以通过 "文件已上传"事件。

这是需要此答案的任何其他人的代码示例。

fanart_uploader.bind('FileUploaded', function(up, file, info) {
    $('#' + file.id + " .tick").show();
    printObject(info);
    var response = jQuery.parseJSON(info.response);
    alert(response.error.message);
});