отправка фрагментов данных со стороны клиента - PullRequest
0 голосов
/ 27 октября 2018

Я использую сокеты для отправки файла.На стороне сервера я слушаю поток со стороны клиента, но со стороны клиента я не могу отправлять данные порциями, которые могут быть отправлены на сторону сервера.Я использовал FileReader для чтения файла по частям. Подскажите, пожалуйста, что я делаю неправильно?

Код клиента

<!DOCTYPE html>
<html>

<head>
    <meta charset=utf-8 />
    <title>Echo server</title>
    <script src="https://ajax.googleapis.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>

<body>
    <h1>File Upload</h1>
    <form id="form" id="chat_form">
        <input type="file" id="file_input" />
        <input type="button" onclick="submit1()" value="submit">
    </form>
    <script src="socket.io/socket.io.js"></script>
    <script type="text/javascript">
        var socket = io('localhost:8080');
        var fReader;
        socket.on('echo', function (data) {
            console.log(data);
        });
        socket.emit('echo', 'this is a message');
        function submit1() {
            var file = $("#file_input")[0].files[0];
            var reader = new FileReader();
            reader.onload = function (evnt) {
                socket.emit('join', { 'Name': Name, Data: evnt.target.result });
            }
            reader.readAsArrayBuffer(file);
        }
    </script>
</body>
</head>

Код СЕРВЕРА

var http = require('http')
var fs = require('fs');
var express = require('express')
var socketio = require('socket.io')
var app = express(server)
var server = http.Server(app)
var io = socketio(server)

app.get('/', function(req, res){
  res.sendFile(__dirname + '/client.html')
});

io.on('connection', function(socket){
  var writeStream  = fs.createWriteStream(__dirname +'/m.png');
  socket.on('echo', function(data){
    socket.emit('echo', data);
  });
  socket.on('join', function(chunk){
    console.log(chunk, "==============chunk=====================");
    writeStream.write(chunk);
  })
});

1 Ответ

0 голосов
/ 27 октября 2018

Вы никогда не отдадите объект file своему объекту FileReader. На самом деле, вы никогда ничего с этим не делаете, поэтому объект FileReader никогда не имеет ничего общего. Например, вы можете сделать:

reader.readAsArrayBuffer(file);

Не похоже, что вы правильно получаете данные от объекта считывателя. Вот примеры кода: Загрузка файла с помощью socket.io и Отправка изображений через Websockets .

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...