将数据从res.write()传递到强大的文件名

时间:2018-08-07 14:54:51

标签: javascript html node.js

我使用节点允许用户上传文件:

var http = require('http');
var formidable = require('formidable');
var fs = require('fs');

http.createServer(function (req, res) {
  if (req.url == '/fileupload') {
    var form = new formidable.IncomingForm();
    form.parse(req, function (err, fields, files) {
      var oldpath = files.filetoupload.path;
      var newpath = 'team_1_uploads/' + files.filetoupload.name + files.filetoupload.token;
      fs.rename(oldpath, newpath, function (err) {
        if (err) throw err;
        res.write('            FILE UPLOADED!');
        res.end();
      });
 });
  } else {
    res.writeHead(200, {'Content-Type': 'text/html'});
    res.write('<div align="center">');
    res.write('<html>');
    res.write('<body>');
    res.write('<form action="fileupload" method="post" enctype="multipart/form-data">');
    res.write('<input id="file_input" type="file" name="filetoupload" style="margin-left: 100px; margin-bottom: 10px; color: transparent"><br>');
    res.write('<input id="submit_button" type="submit">');
    res.write('</form>');
    res.write('</body>');
    res.write('</html>');
    res.write('</div>');
    return res.end();
  }
}).listen(3131);

如您所见,我正在尝试将令牌附加到文​​件名上。节点通过前端的iframe为上载按钮提供服务。通过将以下脚本添加到res.write(),可以使用postMessage将令牌传递给res.write():

res.write("<script>window.addEventListener('message', function(event) { document.getElementById('file_input').dataset.token = event.data; global_hold_token = event.data; })</script>");

这通过使用form元素上的data属性将令牌设置为form元素。通过使用postMessage从前端接收消息:

$('#my_frame')[0].contentWindow.postMessage(token, '*')

我认为我可以使用强大解析数据属性。但是节点似乎无法访问form元素上的data属性,即使它可以访问名称。

1 个答案:

答案 0 :(得分:0)

?token=xxxxxx是GET参数。您可以从req对象下的req.query对象获得这些信息

http://expressjs.com/en/api.html#req.query

因此,在您的情况下,它将位于req.query.token