$ _POST пусто, когда axios отправляет запрос POST CORS - PullRequest
0 голосов
/ 04 ноября 2019

Когда я отправляю запрос POST с данными json в приложении React на сервер PHP, $ _POST пусто. А также php: // input не работает.

Я пытался использовать следующий код.

PHP-сторона сервера:

if($_SERVER['REQUEST_METHOD'] == "OPTIONS") {
    header('Access-Control-Allow-Origin: *');
    header('Access-Control-Allow-Methods: POST, GET, OPTIONS');
    header('Access-Control-Allow-Headers: Accept, Content-Type, Content-Length, Accept-Encoding, X-CSRF-Token, Authorization');
    header('Access-Control-Max-Age: 1000');
    header("Content-Length: 0");
    header("Content-Type: text/plain");
} else if($_SERVER['REQUEST_METHOD'] == "POST") {
    echo "Checking case1:\n";
    echo "<br/>";
    $data = json_decode(file_get_contents('php://input'), true);
    var_dump($data);
    echo "<br/>";
    echo "Checking case2:\n";
    echo "<br/>";
    var_dump($_POST);
}

React-код стороны:

axios.post(
   'https://xx.xx.com/index2.php',
   {
     member: id
   },
   {
     headers: {
       'Content-Type': 'application/x-www-form-urlencoded',
       'Access-Control-Allow-Origin': '*'
           },
     withCredentials: true
   }
)

PHP-сервер работает на CloudFlare. Интересно, связано ли это с процессом кэширования Cloudflare или нет.

Надеюсь, что поможет, заранее спасибо.

Ответы [ 2 ]

0 голосов
/ 04 ноября 2019

при отправке из axios вам нужно изменить заголовки

headers: {
    'Content-Type': 'multipart/form-data,multipart/form-data',
    'Access-Control-Allow-Origin': '*'
}
0 голосов
/ 04 ноября 2019

Используйте заголовки, как показано ниже

Это работает для меня на PHP

headers: {
              Accept: "application/json",
              "Content-Type": "application/x-www-form-urlencoded; charset=UTF-8"
          }
...