• Empleos
  • Sobre nosotros
  • profesionales
    • Inicio
    • Empleos
    • Cursos y retos
    • Preguntas
    • Profesores
  • empresas
    • Inicio
    • Publicar vacante
    • Nuestro proceso
    • Precios
    • Pruebas Online
    • Nómina
    • Blog
    • Comercial
    • Calculadora de salario

0

858
Vistas
solicitud de publicación de axios para enviar datos de formulario

La solicitud POST de axios está accediendo a la url en el controlador pero configurando valores nulos en mi clase POJO, cuando reviso las herramientas de desarrollador en Chrome, la carga útil contiene datos. ¿Qué estoy haciendo mal?

Solicitud POST de Axios:

 var body = { userName: 'Fred', userEmail: 'Flintstone@gmail.com' } axios({ method: 'post', url: '/addUser', data: body }) .then(function (response) { console.log(response); }) .catch(function (error) { console.log(error); });

Respuesta del navegador:

ingrese la descripción de la imagen aquí

Si configuro encabezados como:

 headers:{ Content-Type:'multipart/form-data' }

La solicitud arroja el error.

Error al publicar multipart/form-data. Falta el límite del encabezado de tipo de contenido

Si hago la misma solicitud en cartero, funciona bien y establece valores en mi clase POJO.

¿Alguien puede explicar cómo establecer un límite o cómo puedo enviar datos de formulario usando axios?

about 3 years ago · Santiago Trujillo
3 Respuestas
Responde la pregunta

0

Puede publicar datos de axios usando FormData() como:

 var bodyFormData = new FormData();

Y luego agregue los campos al formulario que desea enviar:

 bodyFormData.append('userName', 'Fred');

Si está cargando imágenes, es posible que desee utilizar .append

 bodyFormData.append('image', imageFile);

Y luego puede usar el método de publicación de axios (puede modificarlo en consecuencia)

 axios({ method: "post", url: "myurl", data: bodyFormData, headers: { "Content-Type": "multipart/form-data" }, }) .then(function (response) { //handle success console.log(response); }) .catch(function (response) { //handle error console.log(response); });

Problema de GitHub relacionado:

No se puede obtener un .post con 'Content-Type': 'multipart/form-data' para trabajar @ axios/axios

about 3 years ago · Santiago Trujillo Denunciar

0

En mi caso, tuve que agregar el límite al encabezado de la siguiente manera:

 const form = new FormData(); form.append(item.name, fs.createReadStream(pathToFile)); const response = await axios({ method: 'post', url: 'http://www.yourserver.com/upload', data: form, headers: { 'Content-Type': `multipart/form-data; boundary=${form._boundary}`, }, });

Esta solución también es útil si está trabajando con React Native.

about 3 years ago · Santiago Trujillo Denunciar

0

Echa un vistazo a la cadena de consulta .

Puedes usarlo de la siguiente manera:

 var querystring = require('querystring'); axios.post('http://something.com/', querystring.stringify({ foo: 'bar' }));
about 3 years ago · Santiago Trujillo Denunciar
Responde la pregunta
Encuentra empleos remotos

¡Descubre la nueva forma de encontrar empleo!

Top de empleos
Top categorías de empleo
Empresas
Publicar vacante Precios Nuestro proceso Comercial
Legal
Términos y condiciones Política de privacidad
© 2025 PeakU Inc. All Rights Reserved.

Andres GPT

Recomiéndame algunas ofertas
Necesito ayuda