画像を保存しました。サイズはバイトで、タイプはmysql dbにあります。
フェッチすると、画像のバッファが返されます。今度は、画像をレンダリングするために、クライアントに送信する方法を理解しようとしていますか?
私のルート内のコード:
const img = await db.images.findByPk(parser.setValueAsBIN(p.id));
const myReadableStreamBuffer = new streamBuffers.ReadableStreamBuffer({
frequency: 10, // in milliseconds.
chunkSize: img.Length, // in bytes.
});
myReadableStreamBuffer.put(img.dataValues.imageData);
次のステップは?
ログに記録する場合はmyReadableStreamBuffer
私はちょうど得ます:
Readable { _readableState: ReadableState {
objectMode: false,
highWaterMark: 16384,
buffer: BufferList { head: null, tail: null, length: 0 },
length: 0,
pipes: null,
pipesCount: 0,
flowing: null,
ended: false,
endEmitted: false,
reading: false,
sync: true,
needReadable: false,
emittedReadable: false,
readableListening: false,
resumeScheduled: false,
paused: true,
emitClose: true,
autoDestroy: false,
destroyed: false,
defaultEncoding: 'utf8',
awaitDrain: 0,
readingMore: false,
decoder: null,
encoding: null }, readable: true, domain: null, _events: [Object: null prototype] {}, _eventsCount: 0, _maxListeners: undefined, stopped: false, stop: [Function], size: [Function], maxSize: [Function], put: [Function], _read: [Function] }
reply.send()
メソッドでサポートストリームとバッファも高速化します。
ここでそれらを管理する方法:
const fs = require('fs')
const { Readable } = require('stream')
const fastify = require('fastify')({ logger: true })
fastify.get('/', (req, reply) => {
const buffer = fs.readFileSync('demo.png')
reply.type('image/png') // if you don't set the content, the image would be downloaded by browser instead of viewed
reply.send(buffer)
})
fastify.get('/stream', (req, reply) => {
const buffer = fs.readFileSync('demo.png') // sync just for DEMO
const myStream = new Readable({
read () {
this.Push(buffer)
this.Push(null)
}
})
reply.type('image/png')
reply.send(myStream)
})
fastify.listen(3000)
(私はstream-buffers
パッケージはメンテナンスされていないようです-未解決の問題-およびnode.jsのデフォルトのstream
モジュールが大幅に改善されました)