--- name: Upload files via HTTP using FormData --- To upload files via HTTP with Bun, use the [`FormData`](https://developer.mozilla.org/en-US/docs/Web/API/FormData) API. Let's start with a HTTP server that serves a simple HTML web form. ```ts#index.ts const server = Bun.serve({ port: 4000, async fetch(req) { const url = new URL(req.url); // return index.html for root path if (url.pathname === "/") return new Response(Bun.file("index.html"), { headers: { "Content-Type": "text/html", }, }); return new Response("Not Found", { status: 404 }); }, }); console.log(`Listening on http://localhost:${server.port}`); ``` --- We can define our HTML form in another file, `index.html`. ```html#index.html Form
``` --- At this point, we can run the server and visit [`localhost:4000`](http://localhost:4000) to see our form. ```bash $ bun run index.ts Listening on http://localhost:4000 ``` --- Our form will send a `POST` request to the `/action` endpoint with the form data. Let's handle that request in our server. First we use the [`.formData()`](https://developer.mozilla.org/en-US/docs/Web/API/Request/formData) method on the incoming `Request` to asynchronously parse its contents to a `FormData` instance. Then we can use the [`.get()`](https://developer.mozilla.org/en-US/docs/Web/API/FormData/get) method to extract the value of the `name` and `profilePicture` fields. Here `name` corresponds to a `string` and `profilePicture` is a `Blob`. Finally, we write the `Blob` to disk using [`Bun.write()`](/docs/api/file-io#writing-files-bun-write). ```ts-diff#index.ts const server = Bun.serve({ port: 4000, async fetch(req) { const url = new URL(req.url); // return index.html for root path if (url.pathname === "/") return new Response(Bun.file("index.html"), { headers: { "Content-Type": "text/html", }, }); + // parse formdata at /action + if (url.pathname === '/action') { + const formdata = await req.formData(); + const name = formdata.get('name'); + const profilePicture = formdata.get('profilePicture'); + if (!profilePicture) throw new Error('Must upload a profile picture.'); + // write profilePicture to disk + await Bun.write('profilePicture.png', profilePicture); + return new Response("Success"); + } return new Response("Not Found", { status: 404 }); }, }); ``` mp;follow=1'>net/dns/dnsmessage/example_test.go (unfollow)
AgeCommit message (Expand)AuthorFilesLines
2018-02-03Add support for base URLs with subfoldersGravatar Frédéric Guillot 10-23/+105
2018-02-01Update German translationGravatar stratmaster 2-4/+12
2018-01-31Add missing about menu in settingsGravatar Frédéric Guillot 5-5/+29
2018-01-31Show API URL endpoints in user interfaceGravatar Frédéric Guillot 11-14/+99
2018-01-29Do not update entry date while refreshing a feedGravatar Frédéric Guillot 1-4/+5
2018-01-29Enable debug mode for integration testsGravatar Frédéric Guillot 1-1/+1
2018-01-29Add the possiblity to enable debug mode with an environment variableGravatar Frédéric Guillot 2-1/+6
2018-01-29Keep code base tidyGravatar Frédéric Guillot 5-18/+16
2018-01-29Add flag to enable debug loggingGravatar Rogier Lommers 2-7/+64
2018-01-25Improve unread counter updatesGravatar Mahendra Kalkura 1-6/+35