如何在两个节点js服务器之间传输文件?

问题描述 投票:4回答:1

我正在尝试创建一个可以托管文件的服务器。这台服务器可以在带有Windows的普通计算机上运行,​​我可以将他的文件传输到另一台计算机。

我已经可以传输基于文本的文件:.txt,.html,.js,但无法传输图像:.png,.jpg

我尝试使用fs.readFile和fs.load,但结果是一样的。

server.js

const http = require('http');
const fs = require('fs');

var port = process.argv[2];

http.createServer((request, response) => {
  console.log('new connection');

  request.on('data',(data)=>{
    let c = JSON.parse(data);

    switch(c.todo[3]){

      case 'downFile':
        if(c.todo[4]&&c.todo[5]){

          let src = c.todo[4];

          let readStream = fs.createReadStream(src);
          readStream.once('error',(err)=>{
            console.log(err);
            response.write(JSON.stringify(err));
            response.end();
          });
          //console.log(readStream);

          readStream.once('end',()=>{
            console.log('copy done');
            response.end();
          });

          readStream.pipe(response);

        }else{
          response.write(JSON.stringify('Need to specify the name of the file'));
          response.end();
        }
        break;

      default:
        //console.log('chexk');
        response.write(JSON.stringify('Unknown command'));
        response.end();
        break;
    }

      // response.write('success');

  })

}).listen(port);

console.log('App Running');

client.js

var request = require('request');
var fs = require('fs');

var port = process.argv[2];
var path = process.argv[3];

var data = {
  json:{
    todo: process.argv
  }
}

var url = 'http://localhost:'+port;
request.post(url,data,(err,res,body)=>{
  if(err)console.log(err)
  else{
    fs.writeFile(process.argv[5]+process.argv[4],body,(err)=>{
      if(err)console.log(err);
    })
  }
})

要启动服务器,我使用: node server.js port 并使我使用的转移: node client.js port downFile inputPath outputPath 对不起英文:/

javascript node.js server file-transfer
1个回答
1
投票

文本和非文本文件传输之间的差异的一种可能解释是资源的Content-Type头。特别是因为你是通过http创建一个较低级别的服务器而不是像express这样的高级服务,你需要小心为正在传输的内容设置一个合适的Content-Type。您可以根据文件扩展名进行推断。

有关HTTP Content-Type标头的更多信息,请查看MDN documentation

© www.soinside.com 2019 - 2024. All rights reserved.