


Que dois-je faire si php $_post ne peut pas accepter les axios ?
Avec la popularité de la séparation front-end et back-end, de plus en plus de développeurs utilisent des frameworks front-end tels que Vue et React, et utilisent axios comme outil permettant au front-end d'envoyer des requêtes au back-end. Cependant, nous rencontrons parfois une situation : lors de l'utilisation d'axios pour envoyer une requête POST, le backend ne peut pas recevoir les données correctement. Cela est lié à la méthode de configuration axios que nous utilisons sur le front-end.
Cet article présentera une situation possible : lors de l'utilisation d'axios pour envoyer une requête POST, le backend ne peut pas recevoir les données correctement. En même temps, nous proposerons une solution de contournement, une solution conçue pour aider les lecteurs à mieux faire face à des situations similaires.
Description du problème
Lorsque nous utilisons Vue+axios pour développer des projets, nous utilisons généralement axios.post()
pour envoyer une requête POST. Cette requête POST contient les données que nous devons envoyer. L'exemple de code spécifique est le suivant : axios.post()
发送一个POST请求,这个POST请求携带了我们所需要发送的数据。具体代码示例如下:
axios.post('/api/submit', { name: '张三', age: 25 }) .then(function (response) { console.log(response); }) .catch(function (error) { console.log(error); });
而在后端,则会用$_POST
来接收这个请求中所携带的数据。示例如下:
$name = $_POST['name']; $age = $_POST['age'];
然而,当我们发送POST请求时,后端却无法正确地接收到数据。
问题原因
造成这种问题的原因在于,axios发送POST请求时默认使用application/json
格式来传递数据,而后端使用$_POST
来接收数据时,需要数据以application/x-www-form-urlencoded
格式传递才能正确接收。如果数据格式不同,后端就会无法正确解析这些数据。
解决方案
为了解决这个问题,我们需要对axios发送请求时的默认请求头进行修改,使之变为application/x-www-form-urlencoded
,具体方法如下:
- 在axios的请求拦截器中添加配置,将请求头的Content-Type设置为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; });
- 将axios.post()方法中的data参数进行URL编码。
axios.post('/api/submit', qs.stringify({ name: '张三', age: 25 })) .then(function (response) { console.log(response); }) .catch(function (error) { console.log(error); });
修改后的代码示例如下:
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); });
经过上述操作后,我们就可以正确地向后端发送POST请求,并成功接收到数据了。
总结
在使用axios发送POST请求时,后端无法正确接收到数据的情况,通常是由于axios发送请求时默认使用application/json
格式来传递数据,而后端使用$_POST
来接收数据时,需要数据以application/x-www-form-urlencoded
格式传递才能正确解析。为了解决这个问题,我们需要对axios的请求拦截器进行配置,将请求头中的Content-Type设置为application/x-www-form-urlencoded
rrreee
$_POST
sera utilisé pour recevoir les données transportées dans cette requête. Un exemple est le suivant : 🎜rrreee🎜 Cependant, lorsque nous envoyons une requête POST, le backend ne peut pas recevoir les données correctement. 🎜🎜Cause du problème🎜La raison de ce problème est qu'axios utilise le format application/json
par défaut pour transmettre des données lors de l'envoi d'une requête POST, tandis que le backend utilise $_POST code> pour recevoir les données Quand, les données doivent être transmises au format <code>application/x-www-form-urlencoded
pour les recevoir correctement. Si le format des données est différent, le backend ne pourra pas analyser les données correctement. 🎜🎜Solution🎜Afin de résoudre ce problème, nous devons modifier l'en-tête de requête par défaut lorsqu'axios envoie une requête afin qu'elle devienne application/x-www-form-urlencoded
. suit : 🎜 - Ajoutez une configuration dans l'intercepteur de requête axios et définissez le Content-Type de l'en-tête de requête sur application/x-www-form-urlencoded.
- L'URL encode le paramètre data dans la méthode axios.post().
application/json
pour transférer les données par défaut lors de l'envoi d'une requête, tandis que axios utilise le format application/json
pour transférer les données par défaut. le backend utilise $_POST est utilisé pour recevoir des données, les données doivent être transmises au format application/x-www-form-urlencoded
pour être analysées correctement. Afin de résoudre ce problème, nous devons configurer l'intercepteur de requête axios, définir le Content-Type dans l'en-tête de la requête sur application/x-www-form-urlencoded
et définir axios.post() Le paramètre data dans la méthode est codé en URL. 🎜Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Outils d'IA chauds

Undresser.AI Undress
Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover
Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool
Images de déshabillage gratuites

Clothoff.io
Dissolvant de vêtements AI

AI Hentai Generator
Générez AI Hentai gratuitement.

Article chaud

Outils chauds

Bloc-notes++7.3.1
Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise
Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1
Puissant environnement de développement intégré PHP

Dreamweaver CS6
Outils de développement Web visuel

SublimeText3 version Mac
Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Sujets chauds

Cet article explore la déduplication efficace du tableau PHP. Il compare les fonctions intégrées comme Array_Unique () avec les approches de hashmap personnalisées, mettant en évidence les compromis de performances en fonction de la taille du tableau et du type de données. La méthode optimale dépend de Profili

Cet article analyse la déduplication du tableau PHP, mettant en évidence les goulots d'étranglement des performances des approches naïves (O (n²)). Il explore des alternatives efficaces à l'aide d'Array_Unique () avec des fonctions personnalisées, des implémentations SplobjectStorage et HashSet, réalisant

Cet article explore la déduplication du tableau PHP en utilisant l'unicité clé. Bien qu'il ne s'agisse pas d'une méthode de suppression en double directe, la mise à profit de l'unicité clé permet de créer un nouveau tableau avec des valeurs uniques en mappant des valeurs aux clés, en écrasant des doublons. Ce AP

Cet article détaille la mise en œuvre des files d'attente de messages en PHP à l'aide de RabbitMQ et Redis. Il compare leurs architectures (AMQP vs en mémoire), les fonctionnalités et les mécanismes de fiabilité (confirmations, transactions, persistance). Meilleures pratiques de conception, erreur

Cet article examine les normes de codage PHP actuelles et les meilleures pratiques, en se concentrant sur les recommandations PSR (PSR-1, PSR-2, PSR-4, PSR-12). Il met l'accent

Cet article détaille l'installation et le dépannage des extensions de PHP, en se concentrant sur PECL. Il couvre les étapes d'installation (trouver, télécharger / compilation, activer, redémarrer le serveur), dépannage des techniques (vérification des journaux, vérification de l'installation,

Cet article explore l'optimisation de la déduplication du tableau PHP pour les grands ensembles de données. Il examine des techniques comme Array_Unique (), Array_flip (), SploBjectStorage et Pre-Sorting, en comparant leur efficacité. Pour les ensembles de données massifs, il suggère de secouer, datab

Cet article explique l'API de réflexion de PHP, permettant l'inspection d'exécution et la manipulation des classes, des méthodes et des propriétés. Il détaille les cas d'utilisation courants (génération de documentation, ORMS, injection de dépendance) et prévient contre la performance Overhea
