Hono OpenAPI
hono-openapi 是一个 中间件,它通过集成 Zod、Valibot、ArkType、TypeBox 以及所有支持 Standard Schema 的库,为你的 Hono API 自动生成 OpenAPI 文档。
🛠️ 安装
将该包与您偏好的验证库及其依赖一起安装:
bash
npm install hono-openapi @hono/standard-validator在本指南中,我们将使用 valibot
bash
npm install valibot @valibot/to-json-schema你可以在这里了解更多安装信息 - https://honohub.dev/docs/openapi#installation
🚀 快速开始
1. 定义你的 Schema
使用你偏好的验证库定义请求和响应的 schema。下面以 Valibot 为例:
ts
import * as v from 'valibot'
const querySchema = v.object({
name: v.optional(v.string()),
})
const responseSchema = v.string()2. 创建路由
使用 describeRoute 为路由添加文档和校验:
ts
import { Hono } from 'hono'
import { describeRoute, resolver, validator } from 'hono-openapi'
const app = new Hono()
app.get(
'/',
describeRoute({
description: 'Say hello to the user',
responses: {
200: {
description: 'Successful response',
content: {
'text/plain': { schema: resolver(responseSchema) },
},
},
},
}),
validator('query', querySchema),
(c) => {
const query = c.req.valid('query')
return c.text(`Hello ${query?.name ?? 'Hono'}!`)
}
)注意:
当使用hono-openapi中的validator()时,添加到query、json、param或form的任何校验都会自动包含在 OpenAPI 请求 schema 中。
无需在describeRoute()中手动定义请求参数。
3. 生成 OpenAPI 规范
为你的 OpenAPI 文档添加一个端点:
ts
import { openAPIRouteHandler } from 'hono-openapi'
app.get(
'/openapi',
openAPIRouteHandler(app, {
documentation: {
info: {
title: 'Hono API',
version: '1.0.0',
description: 'Greeting API',
},
servers: [
{ url: 'http://localhost:3000', description: 'Local Server' },
],
},
})
)想了解更多,请查看文档 - https://honohub.dev/docs/openapi