Решение с помощью CORS с использованием keepalive true

Для моей локальной системы разработки я пытаюсь обслуживать внешние компоненты, используя grunt-contrib-connect. Мне нужно междоменное решение для использования шрифтов в Firefox. Сервер работает отлично, но я не могу получить заголовки.

Я использую версию 0.7.1 из grunt-contrib-connect.

connect: {
        dev: {
            options: {
                port: '9001',
                base: 'build',
                hostname: 'localhost',
                keepalive: true,
                middleware: function(connect, options, middlewares) {
                    // inject a custom middleware into the array of default middlewares
                    // this is likely the easiest way for other grunt plugins to
                    // extend the behavior of grunt-contrib-connect
                    middlewares.push(function(req, res, next) {
                        req.setHeader('Access-Control-Allow-Origin', '*');
                        req.setHeader('Access-Control-Allow-Methods', '*');
                        return next();
                    });

                    return middlewares;
                }
            }
        }
}

Есть ли проблема с использованием keepalive с промежуточным программным обеспечением?

Ответы

Ответ 1

Печально, что никто не ответил на это раньше.

Ваш код выглядит так же, как в документации, но вы добавляете заголовки в req вместо res.

Вторая проблема заключается в том, что docs вводит вас в заблуждение (исправлено), добавляя ваше промежуточное программное обеспечение с помощью .push. Ваш код вообще не вызывается, потому что что-то перед тем, как он делает res.end и/или не вызывает next().

Ваш фиксированный код будет выглядеть так:

    middleware: function (connect, options, middlewares) {
                    // inject a custom middleware 
                    middlewares.unshift(function (req, res, next) {
                        res.setHeader('Access-Control-Allow-Origin', '*');
                        res.setHeader('Access-Control-Allow-Methods', '*');
                        //a console.log('foo') here is helpful to see if it runs
                        return next();
                    });

                    return middlewares;
                }