Подтвердить что ты не робот

Как отправить дополнительные данные формы в Blueimp Uploader?

Я пытаюсь вставить дополнительные данные формы в MYSQL через загрузчик файлов jQuery Blueimp. Но у меня есть некоторые проблемы.

Я использую демо-настройки, и я поменял свой шаблон-загрузку на следующий код (* я добавил вход 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>
  • Как получить дополнительные данные формы?
  • Как изменить .js и UploadHandler.php файл?

Мой второй вопрос: как перенаправить на конкретную загрузку URL?

4b9b3361

Ответ 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

Существует несколько способов отправки дополнительных FormData,

1. Данные о статической форме (если данные формы никогда не изменяются во время выполнения):

Инициализировать FileUpload с помощью

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

2.Dynamic FormData​​p >

Используйте fileuploadsubmit для установки FormData для отправки события

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

Подробнее см. в разделе

Ответ 3

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

Ответ 4

Добавьте элемент ввода внутри формы загрузки файла, как показано ниже:

<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 [ 'additional_data']

например:

$myData = $_REQUEST['additional_data'];

а затем вставьте данные в mysql:

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