Windows 10 reached EOS (end of support) on October 14, 2025. For more information, see this article.

Tìm kiếm hỗ trợ

Tránh các lừa đảo về hỗ trợ. Chúng tôi sẽ không bao giờ yêu cầu bạn gọi hoặc nhắn tin đến số điện thoại hoặc chia sẻ thông tin cá nhân. Vui lòng báo cáo hoạt động đáng ngờ bằng cách sử dụng tùy chọn "Báo cáo lạm dụng".

Tìm hiểu thêm

Firefox multipart/form‑data upload stalls (0 bytes sent) to Next.js pages/api endpoint — works in Edge/Chromium

  • 1 trả lời
  • 0 gặp vấn đề này
  • 1 lượt xem
  • Trả lời mới nhất được viết bởi Denys

Summary: Uploading a file to a custom webapp with Chromium (Edge) works but consistently fails in Firefox. In Firefox the request is created, and times out. The server receives no file and logs “missing file.” The same webapp code is running on both Chromium and Firefox.

Environment:

  • Next.js app (pages/api route)
  • Endpoint: POST /api/file-upload
  • Client: fetch(url, { method: "POST", body: FormData, credentials: "include" })
  • Server: export const config = { api: { bodyParser: false } } + multipart parsing (formidable)
  • Edge/Chromium: Version 141.0.3537.85
  • Firefox Version 147.0.3 (64-bit)
  • OS: Ubuntu 22 / Linux

Steps to reproduce:

  1. Create a FormData object and append a local file:
  const fd = new FormData();
  fd.append("template", file, file.name);
  fetch(`/api/file-upload`, {
    method: "POST",
    body: fd,
  1. In Edge/Chrome, upload succeeds. Server receives multipart body and parses the file. Actual behavior in Firefox:
  • Transferred: 0 B
  • No response status/body
  • Client times out (Upload times out)
  • File upload request received
  • No bytes read server‑side.

Evidence:

  • Edge request logs:
    • content-type: multipart/form-data; boundary=----WebKitFormBoundary...
    • bytesRead ~1.69MB
  • Firefox request logs:
    • Transferred 0 B
    • File upload missing file field

Notes:

  • Client FormData is valid; we log file.name and file.size right before fetch.
  • There is a CSP report‑only warning (frame‑ancestors) when using a fallback iframe approach, but we are not using iframe in the failing case.

Question: Is there a known issue where Firefox blocks or fails to send and multipart/body can be stripped before it leaves the browser? Is there a recommended workaround that does not rely on browser sniffing?

Moderator note: This question has been edited to correct the formatting.

'''Summary:''' Uploading a file to a custom webapp with Chromium (Edge) works but consistently fails in Firefox. In Firefox the request is created, and times out. The server receives no file and logs “missing file.” The same webapp code is running on both Chromium and Firefox. '''Environment:''' * Next.js app (pages/api route) * Endpoint: POST /api/file-upload * Client: fetch(url, { method: "POST", body: FormData, credentials: "include" }) * Server: export const config = { api: { bodyParser: false } } + multipart parsing (formidable) * Edge/Chromium: Version 141.0.3537.85 * Firefox Version 147.0.3 (64-bit) * OS: Ubuntu 22 / Linux '''Steps to reproduce:''' # Create a FormData object and append a local file: <code>const fd = new FormData(); fd.append("template", file, file.<!---->name); fetch(`/api/file-upload`, { method: "POST", body: fd,</code> # In Edge/Chrome, upload succeeds. Server receives multipart body and parses the file. Actual behavior in Firefox: * Transferred: 0 B * No response status/body * Client times out (Upload times out) * File upload request received * No bytes read server‑side. '''Evidence:''' * Edge request logs: ** content-type: multipart/form-data; boundary=----WebKitFormBoundary... ** bytesRead ~1.69MB * Firefox request logs: ** Transferred 0 B ** File upload missing file field '''Notes:''' * Client FormData is valid; we log file.<!---->name and file.size right before fetch. * There is a CSP report‑only warning (frame‑ancestors) when using a fallback iframe approach, but we are not using iframe in the failing case. '''Question:''' Is there a known issue where Firefox blocks or fails to send and multipart/body can be stripped before it leaves the browser? Is there a recommended workaround that does not rely on browser sniffing? ''Moderator note: This question has been edited to correct the formatting.''

Được chỉnh sửa bởi Denys vào

Tất cả các câu trả lời (1)

Hi,

I guess Matrix or Bugzilla will be better places for such kind of questions / bug reports.

Đặt một câu hỏi

Bạn phải đăng nhập vào tài khoản của bạn để trả lời bài viết. Vui lòng bắt đầu một câu hỏi mới, nếu bạn chưa có tài khoản.