skills/bun-guides-http-stream-file/SKILL.md
Stream a file as an HTTP Response
npx skillsauth add jarle/bun-skills Bun Stream a file as an HTTP ResponseInstall this skill globally with one command. Works with Claude Code, Cursor, and Windsurf.
3 of 9 scanners reported clean
Some scanners were skipped, did not run, or reported a non-clean status. Review each row below.
This snippet reads a file from disk using Bun.file(). This returns a BunFile instance, which can be passed directly into the new Response constructor.
const path = "/path/to/file.txt";
const file = Bun.file(path);
const resp = new Response(file);
The Content-Type is read from the file and automatically set on the Response.
new Response(Bun.file("./package.json")).headers.get("Content-Type");
// => application/json;charset=utf-8
new Response(Bun.file("./test.txt")).headers.get("Content-Type");
// => text/plain;charset=utf-8
new Response(Bun.file("./index.tsx")).headers.get("Content-Type");
// => text/javascript;charset=utf-8
new Response(Bun.file("./img.png")).headers.get("Content-Type");
// => image/png
Putting it all together with Bun.serve().
// static file server
Bun.serve({
async fetch(req) {
const path = new URL(req.url).pathname;
const file = Bun.file(path);
return new Response(file);
},
});
See Docs > API > File I/O for complete documentation of Bun.write().
development
Using TypeScript with Bun, including type definitions and compiler options
development
Learn how to write tests using Bun's Jest-compatible API with support for async tests, timeouts, and various test modifiers
testing
Learn how to use snapshot testing in Bun to save and compare output between test runs
testing
Learn about Bun test's runtime integration, environment variables, timeouts, and error handling