dtrotfd1012 2016-10-12 17:06
浏览 164
已采纳

php不接收来自ajax FormData的数据

I'm trying to send multiple data and files by jquery ajax (using formData) to a php file but i don't recive anything in the php file neither $_POST nor $_FILE data, I receive NULL in both.

Here is my ajax function.

$('#formulario').submit(function(e){
    e.preventDefault();
    $.ajax({
        url:"../phpfile.php",
        type:"POST",
        dataType:"JSON",
        data: new FormData(this),
        processData: false,
        contentType: false
    }).always(function(respuesta){
        //code
    });
});

Here is my HTML

<form enctype="multipart/form-data" method="POST">
                        <div class='row'>
                            <div class='col-xs-12'>
                                <h4>Destinatarios</h4>
                                <select class='form-control' required name='destinatarios[]' title='Selecciona cuantos quieras' multiple data-selected-text-format="count>2" data-live-search="true">
                                    {%for familiar in familia%}
                                        <option value='{{familiar.ID_PERSONA}}'>{{familiar.NOMBRE}} {{familiar.APELLIDOS}}</option>
                                    {%endfor%}
                                </select>
                            </div>
                            <div class='col-xs-6 hidden'>
                                <h4>Tipo de entrega</h4>
                                <select class='form-control' id='entrega' name='entrega'>
                                        <option value='1' selected></option>
                                </select>
                            </div>
                        </div>
                        <br>
                        <div class="row">
                            <div class="col-xs-12">
                                <div class="panel panel-default">
                                    <div class="panel-body">
                                        <div class="row">
                                            <div class='col-xs-4 text-center'>
                                                <h4>Despues de mi partida</h4>
                                                <input type="radio" value="muerte" name="tipoE" onchange="cambioR(this)">
                                            </div>
                                            <div class='col-xs-4 text-center'>
                                                <h4>En fecha determinada</h4>
                                                <input type="radio" value="fecha" name="tipoE" onchange="cambioR(this)">
                                            </div>
                                            <div class='col-xs-4 text-center'>
                                                <h4>En mi ceremonia de despedida</h4>
                                                <input type="radio" value="ceremonia" name="tipoE" onchange="cambioR(this)">
                                            </div>
                                        </div>
                                        <br>
                                        <div class="row">
                                            <div id="f" class="hidden">
                                                <div class="col-xs-12">
                                                    <div class="input-group date" id="sandbox-container">
                                                        <span class="input-group-addon">Fecha</span>
                                                        <input type="text" class="form-control date" placeholder="dd/mm/yyyy" name="fecha" id="fecha">
                                                    </div>
                                                    <br>
                                                </div>
                                            </div>
                                            <div id="m" class="hidden">
                                                <div class="col-xs-12">
                                                    <div class="input-group">
                                                        <span class="input-group-addon">Días después de mi partida</span>
                                                        <input class="form-control" id="muerte" name="muerte">
                                                    </div>
                                                    <br>
                                                </div>
                                            </div>
                                        </div>
                                    </div>
                                </div>
                            </div>
                        </div>
                        <div class="row">
                            <div class="col-xs-12">
                                <h4>Mensaje</h4>
                                <input class="hidden" id="nombre_mensaje" name="nombre_mensaje">
                                <textarea class="form-control" rows="10" style="resize: none" id='mensaje' name='mensaje' required></textarea>
                                <br>
                            </div>
                        </div>
                        <div class="row">
                            <div class="col-xs-12">
                                <h4>Imágenes / Video / Audio / Archivos</h4>
                                <div class="grid" id="muestras" dc>
                                    <div class="grid-item col-xs-3 deseo" onclick="novoFile(this);">
                                        <img src="../Recursos/imagenes/plus.jpg" width="100%;">
                                        <input class="hidden" type="file" onchange="cambio(this);" name="files[]">
                                        <input class="hidden datas" name="data_multimedia[]" value="0">
                                    </div>
                                </div>
                            </div>
                        </div>
                        <input class="hidden" id="id_mensaje" name="id_mensaje">
                        <input type="reset" id="reiniciar" hidden>
                    </form>

The user can upload as many files as he want, and the html input file is added dinamicly using jquery.

  • 写回答

1条回答 默认 最新

  • dsl36367 2016-10-12 17:17
    关注

    Try to replace:

    new FormData(this);
    

    with:

    $('#formulario').serialize();
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥15 素材场景中光线烘焙后灯光失效
  • ¥15 请教一下各位,为什么我这个没有实现模拟点击
  • ¥15 执行 virtuoso 命令后,界面没有,cadence 启动不起来
  • ¥50 comfyui下连接animatediff节点生成视频质量非常差的原因
  • ¥20 有关区间dp的问题求解
  • ¥15 多电路系统共用电源的串扰问题
  • ¥15 slam rangenet++配置
  • ¥15 有没有研究水声通信方面的帮我改俩matlab代码
  • ¥15 ubuntu子系统密码忘记
  • ¥15 保护模式-系统加载-段寄存器