dourun2990 2018-06-07 22:28 采纳率: 100%
浏览 79
已采纳

当它到达php页面时,是ajax @post为空

I have the following code where I attempt to post values to a php file using ajax/json. The php file throws warnings saying: Undefined index: companyid, Undefined index: companyname, Undefined index: calendar_eventStart, Undefined index: calendar_eventEnd. I realize that the variables posted using ajax are empty when they are picked up on the server side, but I don't see what I'm doing wrong. Here is my code:

Console log:

Data: {"companyid":1,"companyname":"Fifteen AS","calendar_eventStart":"2018-06-06T22:00:00.000Z","calendar_eventEnd":"2018-06-06T22:00:00.000Z"}

jQuery:

var formData = {
                    companyid,
                    companyname,
                    calendar_eventStart,
                    calendar_eventEnd
                };
                formData = (JSON.stringify(formData));
                console.log('Data: ' + formData);                   
                $.ajax({
                url: "create_calendar_event.php",
                type: "post",
                dataType: "json",   
                data:{data: formData},                   
                success: function(response) {
                alert(response);                
                }               
                });

PHP:

var_dump($_POST['companyid']);
var_dump($_POST['companyname']);
var_dump($_POST['calendar_eventStart']);
var_dump($_POST['calendar_eventEnd']);
$event_status = 'Success';
echo json_encode($event_status,JSON_UNESCAPED_UNICODE|JSON_UNESCAPED_SLASHES);  
  • 写回答

1条回答 默认 最新

  • douchuang1852 2018-06-07 22:40
    关注

    Here

    data:{data: formData},
    

    you are creating a sub-object, therefore the actual data could be found in

    $_POST['data']['companyid'] // etc
    

    IF you didn't JSON.stringify(formData) first. If you keep the stringify $_POST['data'] will only contain a string containing the data. Getting that out needs another magic in php. So just remove the stringify here.

    But you don't need that extra 'data' object. You could just do

    $.ajax({
          url: "create_calendar_event.php",
          type: "post",
          dataType: "json",   
          data: formData, 
          success: function(response) {
               alert(response);                
          }               
    });
    

    final note to JSON.stringify(): I can't think of another situation than sending data via URI (a GET request) that would need to stringify a jsObject.

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥20 你好,我想问下easyExcel下拉多选,或者复选框可以实现吗
  • ¥60 GFSK两点调制锁相环simulink模型
  • ¥20 双非跨考工科哪个专业和方向就业前景好?
  • ¥20 求会6sv辐射传输模型,辅导(可py6s🙏🏻有偿
  • ¥15 .xla后缀的文件拖到excel里什么内容也没有怎么办
  • ¥20 Workbench中Mechanical打不开、闪退是什么原因?
  • ¥240 MapReduce应用实践 学生课程
  • ¥15 hlss视频显示AUTHORITY_INVALID
  • ¥15 MAX9296A+MAX96717,美信gmsl解串有人做过吗?
  • ¥15 求帮我解决一下inode 爆满的问题(有偿)