Solución a errores en notificaciones de Mercado Pago: Webhooks, IPN y problemas de entrega. Diagnóstico y recuperación.
Este error surge generalmente por problemas de conectividad entre tu servidor y los servidores de Mercado Pago. Un código HTTP 500 (Internal Server Error) o 400 (Bad Request) indica un fallo en la comunicación. El sistema de Mercado Pago puede estar experimentando problemas temporales o tu servidor puede estar sobrecargado, impidiendo el procesamiento de las notificaciones.
import crypto from 'node:crypto';
import express from 'express';
const app = express();
app.post('/webhook/mercadopago', express.json(), (req, res) => {
const sig = req.headers['x-signature'] || '';
const ts = sig.match(/ts=(\d+)/)?.[1];
const v1 = sig.match(/v1=([a-f0-9]+)/)?.[1];
const reqId = req.headers['x-request-id'];
const data = `id:${req.body.data.id};request-id:${reqId};ts:${ts};`;
const expected = crypto
.createHmac('sha256', process.env.MP_WEBHOOK_SECRET)
.update(data)
.digest('hex');
if (expected !== v1) return res.sendStatus(401);
// Idempotencia: deduplicar por (data.id, action)
res.sendStatus(200);
});
Comorando intercepta cada evento de Mercado Pago, ejecuta reintentos inteligentes y te avisa cuando hay un problema — sin que escribas una sola línea de código extra.
Automatizá tus pagos gratis →Sin tarjeta de crédito · 250 eventos gratis · En vivo en 5 minutos