我使用节点允许用户上传文件:
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属性,即使它可以访问名称。
答案 0 :(得分:0)
?token=xxxxxx
是GET参数。您可以从req
对象下的req.query
对象获得这些信息
http://expressjs.com/en/api.html#req.query
因此,在您的情况下,它将位于req.query.token