javascript - 运行函数多次返回 "error: Can' 发送后设置 header ”

标签 javascript node.js express http-headers electron

程序按预期运行,直到我尝试再次使用该函数并返回错误:发送后无法设置 header

我正在创建这个应用程序来熟悉nodejs和javascript,我一直在阅读有关该错误的信息,并且在向请求发送多个响应时这似乎是一个问题。在知道这一点之前,我开始使用 res.setHeader,但我读到 res.header 可以避免这个问题,它没有解决它,但我保留了它。

HTML:

<!doctype html>
<head>
    <link rel="stylesheet" type="text/css" href="youtube2music.css">
    <title>
        Youtube2Music
    </title>

</head>
<body>
    <div id="cabeza">
        <h1>
            Youtube 2 Music
        </h1>
        <p>
            just paste your link below and download your song.
        </p>
    </div>
    <div id="down-part">
        <input id="myUrl" class='myUrl-input'>
        </input>
        <button type="button" class="download_button">
        Download
        </button>
    </div>
</body>
<script src='youtube2music.js'></script>
</html>

Javascript:

var urlinput = document.querySelector('.myUrl-input'); // gets url inputbox
var button = document.querySelector('.download_button'); // gets download button

button.addEventListener('click', () => {

  console.log(urlinput.value); // prints in console the url
  sendUrl(urlinput.value); // sends url to function to start the request

});

// function to make requst
function sendUrl(URL){

  window.location.href = `http://localhost:4000/?URL=${URL}`; // makes the video request to nodejs server
}

index.js < Node 文件:

var eventEmitter = new events.EventEmitter();
var sfn;
appi.use(cors());
const {app, BrowserWindow} = require('electron')

function createWindow(){
  let win = new BrowserWindow({width:800, height:600});
  win.loadFile('index.html');
}
app.on('ready', createWindow)

appi.listen(4000, () => {
 console.log('server at port 4000');
});

appi.get('/',(req,res)=>{
 var URL = req.query.URL;
 ytdl.getInfo(URL, function(err,info){
   if(err) throw err;
   var songTitle = info.title;
   sfn = filenamify(songTitle);
   eventEmitter.emit('name_ready');
 });

 var startDownload = function(){
  let stream = ytdl(URL, {
   quality: 'highestaudio',
  });
  res.header('Content-Disposition', 'attachment; filename=' + sfn + '.mp3');
  res.header('Content-type', 'audio/mpeg');
  proc = new ffmpeg({source: stream})
  proc.withAudioCodec('libmp3lame').toFormat('mp3').output(res).run();
 }
 eventEmitter.on('name_ready', startDownload);
})

因为它适用于第一个输入,但要求另一个输出会导致错误,为什么它真的返回此错误以及如何避免?

最佳答案

您当前的设置存在几个问题:

  1. 尽量不要使用事件发射器在 HTTP 请求中发送事件信号,它不是为此而设计的。
  2. 对于 HTTP 请求,尽量不要对请求期间接收到的数据使用全局变量,当两个请求同时传入时,它们可能会感到困惑并发送错误的数据。
appi.listen(4000, () => {
 console.log('server at port 4000');
});

appi.get('/', (req,res)=> {
  const { URL } = req.query;
  ytdl.getInfo(URL, (err,info) => {
    if(err) throw err;
    const songTitle = info.title;
    const sfn = filenamify(songTitle);
    let stream = ytdl(URL, {
      quality: 'highestaudio',
    });
    res.set('Content-Disposition', 'attachment; filename=' + sfn + '.mp3');
    res.set('Content-type', 'audio/mpeg');
    const proc = new ffmpeg({source: stream})
    proc.withAudioCodec('libmp3lame').toFormat('mp3').output(res).run();
  });
})

关于javascript - 运行函数多次返回 "error: Can' 发送后设置 header ”,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/55600896/

相关文章:

node.js - 使用 X509 证书实现 WSSecurity npm 'Soap'

node.js - 聚合查找中面临的问题。需要查找结果与定义的结构相同

javascript - 在 Express.js 中,我是否应该返回响应?

node.js - 尽管已赋值,但变量在函数作用域外未定义?

javascript - 如何在jsp中从多选项卡单一表单打印PDF

javascript - 如何在 Mongoose MongoDb NodeJS 中获取数组中集合中的连接对象

sql - Sequelize belongsToMany 关联不通过表工作

node.js - 使用 Socket.io 而不是普通的 ajax 调用会阻止服务器耗尽 TCP 套接字吗?

javascript - "overflow-x: scroll"的百分比宽度 <div> 不起作用,即使在跨度内

javascript - 当我点击另一个内容是从数据库生成的div时,如何更改div的内容