search
HomeBackend DevelopmentPHP ProblemWhat should I do if php $_post cannot accept axios?

With the popularity of front-end and back-end separation, more and more developers are using front-end frameworks such as Vue and React, and using axios as a tool for the front-end to send requests to the back-end. However, sometimes we encounter a situation: when using axios to send a POST request, the backend cannot receive the data correctly. This is related to the axios configuration method we use on the front end.

This article will introduce a possible situation: using axios to send a POST request, the backend cannot receive the data correctly. At the same time, we will provide a workaround, a solution designed to help readers better cope with similar situations.

Problem description
When using Vue axios to develop projects, we usually use axios.post() to send a POST request. This POST request carries the data we need to send. . The specific code example is as follows:

axios.post('/api/submit', {
    name: '张三',
    age: 25
})
.then(function (response) {
    console.log(response);
})
.catch(function (error) {
    console.log(error);
});

On the backend, $_POST will be used to receive the data carried in this request. An example is as follows:

$name = $_POST['name'];
$age = $_POST['age'];

However, when we send a POST request, the backend cannot receive the data correctly.

Cause of the problem
The reason for this problem is that axios uses the application/json format to transfer data by default when sending a POST request, while the backend uses $_POSTWhen receiving data, the data needs to be passed in the application/x-www-form-urlencoded format to receive it correctly. If the data format is different, the backend will not be able to parse the data correctly.

Solution
In order to solve this problem, we need to modify the default request header when axios sends a request so that it becomes application/x-www-form-urlencoded, The specific method is as follows:

  1. Add configuration in the axios request interceptor and set the Content-Type of the request header to application/x-www-form-urlencoded.
axios.interceptors.request.use(config => {
    if (config.method === 'post') {
        config.headers['Content-Type'] = 'application/x-www-form-urlencoded';
    }
    return config;
});
  1. URL encode the data parameter in the axios.post() method.
axios.post('/api/submit', qs.stringify({
    name: '张三',
    age: 25
}))
.then(function (response) {
    console.log(response);
})
.catch(function (error) {
    console.log(error);
});

The modified code example is as follows:

axios.interceptors.request.use(config => {
    if (config.method === 'post') {
        config.headers['Content-Type'] = 'application/x-www-form-urlencoded';
    }
    return config;
});

axios.post('/api/submit', qs.stringify({
    name: '张三',
    age: 25
}))
.then(function (response) {
    console.log(response);
})
.catch(function (error) {
    console.log(error);
});

After the above operations, we can correctly send the POST request to the backend and successfully receive the data.

Summary
When using axios to send a POST request, the backend cannot receive the data correctly. This is usually because axios uses the application/json format to transfer data by default when sending a request. , and when the backend uses $_POST to receive data, the data needs to be passed in the application/x-www-form-urlencoded format to be parsed correctly. In order to solve this problem, we need to configure the axios request interceptor, set the Content-Type in the request header to application/x-www-form-urlencoded, and set the axios.post() method The data parameters in are URL encoded.

The above is the detailed content of What should I do if php $_post cannot accept axios?. For more information, please follow other related articles on the PHP Chinese website!

Statement
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

Video Face Swap

Video Face Swap

Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Hot Tools

SublimeText3 Linux new version

SublimeText3 Linux new version

SublimeText3 Linux latest version

MantisBT

MantisBT

Mantis is an easy-to-deploy web-based defect tracking tool designed to aid in product defect tracking. It requires PHP, MySQL and a web server. Check out our demo and hosting services.

Zend Studio 13.0.1

Zend Studio 13.0.1

Powerful PHP integrated development environment

SAP NetWeaver Server Adapter for Eclipse

SAP NetWeaver Server Adapter for Eclipse

Integrate Eclipse with SAP NetWeaver application server.

VSCode Windows 64-bit Download

VSCode Windows 64-bit Download

A free and powerful IDE editor launched by Microsoft