Bun
Bun 是另一个 JavaScript 运行时。它不是 Node.js 或 Deno。Bun 包含一个转译编译器,我们可以用 TypeScript 编写代码。 Hono 也可以在 Bun 上运行。
1. 安装 Bun
要安装 bun 命令,请按照官方网站中的说明进行操作。
2. 设置
2.1. 设置一个新项目
有一个适用于 Bun 的入门模板。使用“bun create”命令开始您的项目。 本例选择 bun 模板。
sh
bun create hono@latest my-app进入 my-app 并安装依赖项。
sh
cd my-app
bun install2.2. 设置现有项目
在现有的 Bun 项目中,我们只需要在项目根目录中通过以下方式安装 hono 依赖项
sh
bun add hono3. Hello World
“Hello World”脚本如下。几乎与其他平台上的写法相同。
ts
import { Hono } from 'hono'
const app = new Hono()
app.get('/', (c) => c.text('你好 Bun!'))
export default app4. 运行
运行命令。
sh
bun run dev然后,在您的浏览器中访问 http://localhost:3000。
更改端口号
您可以通过导出 port 来指定端口号。
ts
import { Hono } from 'hono'
const app = new Hono()
app.get('/', (c) => c.text('你好 Bun!'))
export default app
export default {
port: 3000,
fetch: app.fetch,
} 提供静态文件
要提供静态文件,请使用从 hono/bun 导入的 serveStatic。
ts
import { serveStatic } from 'hono/bun'
const app = new Hono()
app.use('/static/*', serveStatic({ root: './' }))
app.use('/favicon.ico', serveStatic({ path: './favicon.ico' }))
app.get('/', (c) => c.text('您可以访问:/static/hello.txt'))
app.get('*', serveStatic({ path: './static/fallback.txt' }))对于上面的代码,它将与以下目录结构很好地配合使用。
./
├── favicon.ico
├── src
└── static
├── demo
│ └── index.html
├── fallback.txt
├── hello.txt
└── images
└── dinotocat.pngrewriteRequestPath
如果您想将 http://localhost:3000/static/* 映射到 ./statics,可以使用 rewriteRequestPath 选项:
ts
app.get(
'/static/*',
serveStatic({
root: './',
rewriteRequestPath: (path) =>
path.replace(/^\/static/, '/statics'),
})
)mimes
您可以使用 mimes 添加 MIME 类型:
ts
app.get(
'/static/*',
serveStatic({
mimes: {
m3u8: 'application/vnd.apple.mpegurl',
ts: 'video/mp2t',
},
})
)onFound
您可以使用 onFound 指定找到请求文件时的处理方式:
ts
app.get(
'/static/*',
serveStatic({
// ...
onFound: (_path, c) => {
c.header('Cache-Control', `public, immutable, max-age=31536000`)
},
})
)onNotFound
您可以使用 onNotFound 指定未找到请求文件时的处理方式:
ts
app.get(
'/static/*',
serveStatic({
onNotFound: (path, c) => {
console.log(`${path} 未找到,您访问了 ${c.req.path}`)
},
})
)precompressed
precompressed 选项会检查是否存在带有 .br 或 .gz 等扩展名的文件,并根据 Accept-Encoding 标头提供它们。它优先使用 Brotli,然后是 Zstd,最后是 Gzip。如果都不存在,则提供原始文件。
ts
app.get(
'/static/*',
serveStatic({
precompressed: true,
})
)测试
您可以使用 bun:test 在 Bun 上进行测试。
ts
import { describe, expect, it } from 'bun:test'
import app from '.'
describe('我的第一个测试', () => {
it('应返回 200 响应', async () => {
const req = new Request('http://localhost/')
const res = await app.fetch(req)
expect(res.status).toBe(200)
})
})然后,运行命令。
sh
bun test index.test.ts