Skip to content

流式助手

流式助手提供了用于流式响应的方法。

导入

ts
import { Hono } from 'hono'
import { stream, streamText, streamSSE } from 'hono/streaming'

stream()

它返回一个简单的流式响应,作为 Response 对象。

ts
app.get('/stream', (c) => {
  return stream(c, async (stream) => {
    // 编写当请求中止时要执行的过程。
    stream.onAbort(() => {
      console.log('Aborted!')
    })
    // 写入一个 Uint8Array。
    await stream.write(new Uint8Array([0x48, 0x65, 0x6c, 0x6c, 0x6f]))
    // 管道传输一个可读流。
    await stream.pipe(anotherReadableStream)
  })
})

streamText()

它返回一个带有 Content-Type:text/plainTransfer-Encoding:chunkedX-Content-Type-Options:nosniff 头部的流式响应。

ts
app.get('/streamText', (c) => {
  return streamText(c, async (stream) => {
    // 写入带换行符 ('\n') 的文本。
    await stream.writeln('Hello')
    // 等待 1 秒。
    await stream.sleep(1000)
    // 写入不带换行符的文本。
    await stream.write(`Hono!`)
  })
})

WARNING

如果您正在为 Cloudflare Workers 开发应用程序,流式传输在 Wrangler 上可能无法正常工作。如果是这样,请为 Content-Encoding 头部添加 Identity

ts
app.get('/streamText', (c) => {
  c.header('Content-Encoding', 'Identity')
  return streamText(c, async (stream) => {
    // ...
  })
})

streamSSE()

它允许您无缝流式传输服务器发送事件 (SSE)。

ts
const app = new Hono()
let id = 0

app.get('/sse', async (c) => {
  return streamSSE(c, async (stream) => {
    while (true) {
      const message = `It is ${new Date().toISOString()}`
      await stream.writeSSE({
        data: message,
        event: 'time-update',
        id: String(id++),
      })
      await stream.sleep(1000)
    }
  })
})

错误处理

流式助手的第三个参数是错误处理程序。 此参数是可选的,如果您不指定它,错误将作为控制台错误输出。

ts
app.get('/stream', (c) => {
  return stream(
    c,
    async (stream) => {
      // 编写当请求中止时要执行的过程。
      stream.onAbort(() => {
        console.log('Aborted!')
      })
      // 写入一个 Uint8Array。
      await stream.write(
        new Uint8Array([0x48, 0x65, 0x6c, 0x6c, 0x6f])
      )
      // 管道传输一个可读流。
      await stream.pipe(anotherReadableStream)
    },
    (err, stream) => {
      stream.writeln('An error occurred!')
      console.error(err)
    }
  )
})

回调执行完毕后,流将自动关闭。

WARNING

如果流式助手的回调函数抛出错误,Hono 的 onError 事件将不会被触发。

onError 是一个在响应发送之前处理错误并覆盖响应的钩子。但是,当回调函数执行时,流已经启动,因此无法被覆盖。