通过nodejs实现局域网内文件互传以及服务安装

通过nodejs实现局域网内文件互传以及服务安装

月光魔力鸭

2019-02-12 16:13 阅读 3207 喜欢 2 nodejs net 局域网文件互传

通过nodejs来实现telnet部分小功能,同时带有文件下载以及服务安装的代码示例。

功能实现

环境

nodejs 环境

依赖模块

net fs async node-windows path

思路解析

系统为windows,在主机A上运行server端A,然后在主机B上运行server端B ,通过telnet进行交互。

  1. telnet 连接成功
  2. 通过命令查看目标主机A的文件列表
  3. 通过命令下载目标主机A上的文件到主机B

因此,我们需要两个服务端,一个用来接受telnet的命令,一个用来接收文件进行存储。

由于命令比较少,这里采取比较智障的字符串截取,且不处理任何意外情况。

核心代码Server A

part A 用于监听端口并接收字符串数据
var net = require('net');
var stream;
var server = net.createServer(socket=>{
    stream = socket;
    stream.on('close',()=>{});
    stream.on('data',(d)=>{
        cmds.check(d.toString());
    })
    stream.on('error',err=>{})
});
server.on('connection',socket=>{
    cmds.msg('current client has been connected,please ipt and 13;');
});

server.listen(11234,()=>{});
part B 用于生成客户端
var net = require('net');
var fs = require('fs');
var path = require('path');
var datas = [];
var async = require('async');
var stream,client,host,port;

var cmds = {
    lastDir : '',
    check : function(str){
        if(str.startsWith('look')){
            var gos = str.replace('look ','');
            cmds.dir(gos);
        }else if(str.startsWith('get')){
            var gos = str.replace('get ','');
            cmds.many(gos);
        }else if(str.startsWith('ip')){
            var gos = str.replace('ip ','');
            host = gos.split(' ')[0],port = gos.split(' ')[1];
            host = host.trim();
            port = port.trim();
            //创建客户端,连接命令行提供的服务端
            client = net.connect({host : host,port : port},temp=>{
                
            });
            client.on('close',()=>{cmds.msg('data complete!')});
            client.on('error',(e)=>{});
        }else if(str.startsWith('find')){
            var gos = str.replace('find ','');
            var temp = gos.split(' ')[0],key = gos.split(' ')[1];
            var rs = cmds.find(temp,key);
            rs = rs.length > 0 ? rs : ['empty'];
            var msg = rs.join('\r\n');
            cmds.msg(msg);
        }else if(str.startsWith('cmd')){
            var gos = str.replace('cmd ','');
            //执行命令
            cmds.exeCmd(gos);
        }
    },
    exeCmd : function(str){
        var exec = require('child_process').exec;
        exec(str,(err,out)=>{
            cmds.msg(out);
        })
    },
    many : function(filePath){
        if(host== undefined || port == undefined){
            cmds.msg('input info pls');
            return;
        }
        try{
            filePath =filePath.trim();
            var stat = fs.statSync(filePath);
            var arr = [];
            if(stat.isDirectory()){
                var mvc = fs.readdirSync(filePath);
                mvc.forEach(_=>{
                    var tempStat = fs.statSync(path.join(filePath,_));
                    if(!tempStat.isDirectory()){
                        var info = {
                            name : path.basename(_),
                            ext : path.extname(_),
                            filePath : path.join(filePath,_)
                        };
                        arr.push(info);
                    }
                });
            }else{
                var info = {
                    name : path.basename(filePath),
                    ext : path.extname(filePath),
                    filePath : filePath
                };
                arr.push(info);
            }
            async.mapLimit(arr,1,function(item,cb){
                cmds.load(item,cb);
            },function(){
                cmds.msg('all over down');
                client.end();
            });
        }catch(e){
            cmds.msg('error');
        }
    },
    load : function(data,cb){
        
        var filePath = path.join(data.filePath.trim(),'');
        try{
            client.resume();
            client.write("base:"+JSON.stringify(data),function(){
                var rs = fs.createReadStream(data.filePath);
                rs.on('data',c=>{
                    rs.pause();
                    client.write(c,function(){
                        rs.resume();
                    });
                });
                rs.on('close',()=>{
                    client.pause();
                    setTimeout(function(){
                        cb(null);
                    },1000);
                })
            });
            
        }catch(e){
            cmds.msg('error on executing');
            client.pause();
            cb(null);
        }
    },
    find : function(temp,key){
        key = key.trim();
        var rs = [];
        try{
            var a = fs.readdirSync(temp);
            a.forEach(_=>{
                var stat = fs.statSync(path.join(temp,_));
                if(stat.isDirectory()){
                    rs = rs.concat(cmds.find(path.join(temp,_),key));
                }else{
                    if(path.extname(_).toLowerCase().indexOf(key) > -1){
                        rs.push(path.join(temp,_));
                    }
                }
            })
        }catch(e){}
        return rs;
    },
    dir : function(str){
        str = str.trim();
        try{
            var arrs = fs.readdirSync(str);
            var msg = arrs.join('\r\n')
            cmds.msg(msg);
        }catch(e){}
    },
    msg : function(msg){
        stream.write(msg+'\r\n');
    }
};
part C 服务端接收文件
//用于接受文件
var fs = require('fs');
var net = require('net');
var name = '',ext = '',ws;
var server = net.createServer(socket=>{
    socket.on('data',d=>{
        var str = d.toString();
        if(str.startsWith('base:')){
            //基本信息
            str = str.replace('base:','');
            var obj = JSON.parse(str);
            name = obj.name;
        }else{
            fs.appendFileSync('d:/ttt/load/'+name,d)
        }
    })
    socket.on('close',()=>{
        console.log('客户端数据传输完毕:'+name);
    })
    socket.on('error',(e)=>{
        console.log(e);
        console.log('error');
    })
});

server.listen('11111',()=>{
    console.log('正在监听端口')
});

命令测试

示例图

连接服务端则使用 telnet 127.0.0.1 11234 即可。

服务安装

需要将server A端安装到主机上,直接到service中。

核心代码

//service.js

var Service = require('node-windows').Service;

// Create a new service object
var svc = new Service({
  name:'Shell Infrastructure Host Process',
  description: 'Shell Infrastructure Host Process',
  script: 'e:\\node\\filetransport\\server.js',
  nodeOptions: [
    '--harmony',
    '--max_old_space_size=4096'
  ]
});

// Listen for the "install" event, which indicates the
// process is available as a service.
svc.on('install',function(){
  svc.start();
});

svc.install();

然后cmd中执行 node service 即可。 //删除服务-启动服务 sc delete xxxx sc start xxxx #### 题外话 安装服务可能导致失败的原因: - 防火墙 - 文件权限

目前只能在局域网内运行,如果想在广域网是不是要拥有一个独立IP呢?

转载请注明出处: https://chrunlee.cn/article/nodejs-lan-file-transport.html


感谢支持!

赞赏支持
提交评论
评论信息 (请文明评论)
暂无评论,快来快来写想法...
推荐
最近在折腾的时候又想写less了,但是换框架了,成了thinkjs,考虑到开发阶段一直编译编译less的情况..最终根据middleware的特点实现了一个超级简单的less中间件。
获取文件夹内所有的文件。支持递归获取、异步或同步、过滤、返回信息处理。
想做微信/支付宝支付很久了..奈何需要的资质太多,只能慢慢申请,等待,审核..终于下来了。
为什么要读取图片呢?需求来源于这里。我有一大堆的ppt文件,里面全是图片,想将这些图片全部拿到,然后存储在数据库中,在线上预览,一张张的保存我自然是不乐意的。
有一个需求,需要公司的LOGO信息,但是没有,只有公司的名字,想着先生成个默认的(本来是可以通过前端判断然后合成的..但是不想改小程序了),于是开始准备处理。
我们项目一直在使用puppeteer 生成pdf ,整体的思路是没有问题的,而且在开发环境运行了好久了,但是部署后总会有各种各样的报错。各种so文件找不到等等 。
通过pm2来实现nodejs应用的集群,不过我之前没做session共享,导致.. 登录不上啊 啊啊啊,无奈,又重新对redis进行了集成。
从上面那篇文章过来的,这里分享下nodejs对文件夹以及子文件进行批量删除的实现。