コンテンツへスキップ

Streaming Helper

ストリーミングヘルパーは、ストリーミング応答のためのメソッドを提供します。

Import

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

stream()

Responseオブジェクトとして、簡単なストリーミング応答を返します。

ts
app.get('/stream', (c) => {
  return stream(c, async (stream) => {
    // Write a process to be executed when aborted.
    stream.onAbort(() => {
      console.log('Aborted!')
    })
    // Write a Uint8Array.
    await stream.write(new Uint8Array([0x48, 0x65, 0x6c, 0x6c, 0x6f]))
    // Pipe a readable stream.
    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) => {
    // Write a text with a new line ('\n').
    await stream.writeln('Hello')
    // Wait 1 second.
    await stream.sleep(1000)
    // Write a text without a new line.
    await stream.write(`Hono!`)
  })
})

警告

Cloudflareワーカー用のアプリケーションを開発している場合、ストリーミングは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)
    }
  })
})

エラー処理

ストリーミングヘルパーの3番目の引数はエラーハンドラーです。この引数はオプションです。指定しない場合、エラーはコンソールエラーとして出力されます。

ts
app.get('/stream', (c) => {
  return stream(
    c,
    async (stream) => {
      // Write a process to be executed when aborted.
      stream.onAbort(() => {
        console.log('Aborted!')
      })
      // Write a Uint8Array.
      await stream.write(
        new Uint8Array([0x48, 0x65, 0x6c, 0x6c, 0x6f])
      )
      // Pipe a readable stream.
      await stream.pipe(anotherReadableStream)
    },
    (err, stream) => {
      stream.writeln('An error occurred!')
      console.error(err)
    }
  )
})

コールバックが実行された後、ストリームは自動的に閉じられます。

警告

ストリーミングヘルパーのコールバック関数がエラーをスローした場合、HonoのonErrorイベントはトリガーされません。

onError は、応答が送信される前にエラーを処理し、応答を上書きするフックです。ただし、コールバック関数が実行されると、ストリームはすでに開始されているため、上書きすることはできません。

MIT ライセンスでリリースされています。