node.jsより,fsモジュールを用いて画像ファイルをバッファとして,socket.ioでクライアント側に送りました.
しかし,ブラウザでは表示が出来ません.
ブラウザには?マークが出力され,コンソールを見てみると,ArrayBufferと書いてありました.
変換の操作が必要だと思うのですが,何型に変換をすればいいのか分かりません.
よろしくお願いいたします.
node
1socket.on("t",(data)=>{ 2 3let dir = process.env[process.platform == "win32" ? "USERPROFILE" : "HOME"] ; 4let savepath = dir+"/Desktop/save"; 5 fs.readdir(savepath, (err, folder) => { 6 for(let i=0 ; i<folder.length ;i++){ 7 console.log(folder[i]) ; 8 fs.readdir(savepath+"/"+folder[i], (err, files) => { 9 console.log(files) ; 10 fs.readFile(savepath+"/"+folder[i]+"/"+files,(err,data) => { 11 socket.emit('image', data); 12 console.log('image file is initialized'); 13}); 14 }) 15} 16}); 17}) 18
html
1<!DOCTYPE html> 2<html lang="ja" dir="ltr"> 3 <head> 4 <meta charset="utf-8"> 5 <title>teacher</title> 6 <script src="http://name.local:3000/socket.io/socket.io.js"></script> 7 </head> 8 <body> 9 <h3><span id = "logs"> 10 <script> 11 let socket = io.connect() ; 12 socket.emit("t","connect") ; 13 socket.on("image", function(data) { 14 console.log(data); 15 $("#logs").append("<img src="+data+">") ; 16 }) ; 17 </script> 18 </body> 19</html> 20
回答1件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
2019/02/06 02:34