Raddy Website Design & Development Tutorials

Next.js 14.0.2 x-forwarded-host header with value localhost:3000 does not match origin – Fix

By Raddy in Other ·

If you encounter the ‘x-forwarded-host’ header mismatch error while utilizing Server Actions in Next.js 14.0.2 (self-hosted on Linux Ubuntu with Nginx), specifically when the ‘x-forwarded-host’ header value is ‘localhost:3000’ and does not align with the ‘origin’ header value, this solution aims to address and resolve the issue.

Error: x-forwarded-host header with value localhost:3000 does not match origin header with value.

The way I managed to spot and debug the issue was by opening “pm2 monit” and triggering a server action – in this case, updating a record.

nextjs server actions not working

Fix

Here is what worked for me. You need to add allowedOrigins in experimental, serverActions:

/** @type {import('next').NextConfig} */
const nextConfig = {
  experimental: {
    serverActions: {
      allowedOrigins: ["website.com", "localhost:3000"]
    }
  }
}

module.exports = nextConfig

For more, follow this Github thread.

Leave a Reply

Your email address will not be published. Required fields are marked *

This site uses Akismet to reduce spam. Learn how your comment data is processed.