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 $_POST
When 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:
- 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; });
- 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!

This article details implementing message queues in PHP using RabbitMQ and Redis. It compares their architectures (AMQP vs. in-memory), features, and reliability mechanisms (confirmations, transactions, persistence). Best practices for design, error

This article examines current PHP coding standards and best practices, focusing on PSR recommendations (PSR-1, PSR-2, PSR-4, PSR-12). It emphasizes improving code readability and maintainability through consistent styling, meaningful naming, and eff

This article explains PHP's Reflection API, enabling runtime inspection and manipulation of classes, methods, and properties. It details common use cases (documentation generation, ORMs, dependency injection) and cautions against performance overhea

This article details installing and troubleshooting PHP extensions, focusing on PECL. It covers installation steps (finding, downloading/compiling, enabling, restarting the server), troubleshooting techniques (checking logs, verifying installation,

This article explores asynchronous task execution in PHP to enhance web application responsiveness. It details methods like message queues, asynchronous frameworks (ReactPHP, Swoole), and background processes, emphasizing best practices for efficien

PHP 8's JIT compilation enhances performance by compiling frequently executed code into machine code, benefiting applications with heavy computations and reducing execution times.

This article addresses PHP memory optimization. It details techniques like using appropriate data structures, avoiding unnecessary object creation, and employing efficient algorithms. Common memory leak sources (e.g., unclosed connections, global v

This article explores strategies for staying current in the PHP ecosystem. It emphasizes utilizing official channels, community forums, conferences, and open-source contributions. The author highlights best resources for learning new features and a


Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

AI Hentai Generator
Generate AI Hentai for free.

Hot Article

Hot Tools

EditPlus Chinese cracked version
Small size, syntax highlighting, does not support code prompt function

ZendStudio 13.5.1 Mac
Powerful PHP integrated development environment

VSCode Windows 64-bit Download
A free and powerful IDE editor launched by Microsoft

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Dreamweaver Mac version
Visual web development tools