如何向Blueimp Uploader提交额外的表格数据?

时间:2012-12-13 20:45:45

标签: php mysql jquery-ui blueimp

我正在尝试通过Blueimp jquery文件上传器将其他表单数据插入MYSQL。但我有一些问题。

我正在使用演示设置,我将模板上传更改为以下代码(*我添加了Notunuz输入)

<script id="template-upload" type="text/x-tmpl">
{% for (var i=0, file; file=o.files[i]; i++) { %}
    <tr class="template-upload fade">
        <td class="preview"><span class="fade"></span></td>
        <td class="title"><label>Notunuz: <input name="title[]"></label></td>
        {% if (file.error) { %}
            <td class="error" colspan="2"><span class="label label-important">Hata</span> {%=file.error%}</td>
        {% } else if (o.files.valid && !i) { %}
            <td>
                <div class="progress progress-success progress-striped active" role="progressbar" aria-valuemin="0" aria-valuemax="100" aria-valuenow="0"><div class="bar" style="width:0%;"></div></div>
            </td>
            <td class="start">{% if (!o.options.autoUpload) { %}
                <button class="btn btn-primary">
                    <i class="icon-upload icon-white"></i>
                    <span>Başlat</span>
                </button>
            {% } %}</td>
        {% } else { %}
            <td colspan="2"></td>
        {% } %}

    </tr>
{% } %}
</script>
  • 如何获取其他表单数据?
  • 如何更改.jsUploadHandler.php文件?

我的第二个问题是如何重定向到特定的网址上传?

4 个答案:

答案 0 :(得分:2)

发送其他FormData的方法有多种,

1.静态表格数据(如果表格数据在运行时永远不会改变):

使用

初始化FileUpload
 $('#fileupload').fileupload({
         formData: {
            "data1": data1,
            "data2": data2
        }
     });

2.Dynamic FormData

使用fileuploadsubmit在提交事件

上设置FormData
$('#formData').fileupload({
   .........
}).on('fileuploadsubmit', function (e, data) {
    data.formData = {
         "data1": data1,
         "data2": data2
    };
});

更多详情请参阅:

答案 1 :(得分:1)

我喜欢,

$('#fileupload').fileupload({
    formData: {example: 'test'}
});

更具活力,

 <input type="text" name="name" value="" id="inpName" /> /* example 1 */
 <span id="spnHash" style="display:none">ttt-vvv-hh</span> /* example 2 */
 $('#fileupload').fileupload({
    var $formData = {
        "name": $("#inpName").val(),
        "hash": $("#spnHash").text()
    }
     formData: $formData
 });

重定向:

https://github.com/blueimp/jQuery-File-Upload/issues/670#issuecomment-2291997

答案 2 :(得分:0)

    $('#file-upload').fileupload({
      formData: {key: 'value'}
    });

答案 3 :(得分:0)

在fileupload表单中添加一个input元素,如下所示:

<form id="fileupload" action="/server/php" method="POST" enctype="multipart/form-data">
    <input type="text" name="additional_data" value="your_value" hidden >
</form>

然后在UploadHandler.php中,您可以使用获取输入的值 $ _REQUEST [&#39; additional_data&#39;]

例如:

$myData = $_REQUEST['additional_data'];

然后将数据插入mysql:

$conn = new mysqli($servername, $username, $password, $dbname);
$conn->query("INSERT INTO your_tbl(your_field) VALUES ('$myData')");