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/plain
、Transfer-Encoding:chunked
、X-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
は、応答が送信される前にエラーを処理し、応答を上書きするフックです。ただし、コールバック関数が実行されると、ストリームはすでに開始されているため、上書きすることはできません。