小编典典

axios http始终返回空数据

reactjs

我之前问过这个问题,但无法得到答案。我能够使用方法:像下面的“
get”使它正常工作,所以还可以,但是这次我需要使用post。在另一个项目中(使用react,redux,php,webpack,xampp),同样的问题浮出水面,我正在尝试解决。所以这里是:

register.php

  echo $_GET['task'];

index.js

  const values = {task: 'doSomething', username: 'username'}
  axios({
      url: "./server/register.php",
      timeout: 20000,
      method: 'get',
      params: values
  }).then(function(response){console.log(response.data)})

当我执行上述操作时,一切正常,数据以“ doSomething”的身份注销。但是,当我尝试使用axios({method:’POST’})并将php更改为$
_POST [‘task’]时,出现一个错误,提示$ _POST [‘task’]未定义,如下所示:

index.js

  axios({
      url: "/projects/myProject/server/register.php",
      method: 'post',
      data: values
  }).then(function(response){console.log(response.data)})

register.php

echo $_POST['task'];

注意 :未定义的索引:任务

另外,当我使用axios.post()尝试此操作时,我遇到了完全相同的问题。我想在这里使用发帖请求。谁能为我阐明一下?


阅读 415

收藏
2020-07-22

共1个答案

小编典典

好吧,我挠了一下头后,我找到了答案。在PHP上,必须添加此行,然后才能访问任何POST数据:

$_POST = json_decode(file_get_contents('php://input'), true);
echo $_POST['task'];

根据我的理解,从axios输入的数据是JSON,因此我们必须使用file_get_contents()将其以JSON编码的字符串形式返回,然后使用json_decode将其转换为JSON编码的php变量。希望这对其他人有帮助。谢谢。

2020-07-22