如何将 CORS-Headers 添加到静态连接服务器?

Posted

技术标签:

【中文标题】如何将 CORS-Headers 添加到静态连接服务器?【英文标题】:How can I add CORS-Headers to a static connect server? 【发布时间】:2013-06-12 01:17:48 【问题描述】:

我正在编写一个提供静态 html、css 和 javascript 的小型演示 Web 服务器。 服务器看起来像

(function () 
    "use strict";

    var http = require("http");
    var connect = require('connect');
    var app = connect()
        .use(connect.logger('dev'))
        .use(connect.static('home'));

    var server = http.createServer(app);
    server.listen(9999, function () 
        console.log('server is listening');
    );
)();

我的客户端 javascript 对不同的服务器进行 ajax 调用。 如何添加

Access-Control-Allow-Origin: http://example.com

到我的服务器响应,以便客户端javascript可以进行ajax调用?

【问题讨论】:

【参考方案1】:

因为express 宠坏了我,所以想弄清楚这个有点麻烦。

看看enable cors。基本上您需要做的是将Access-Control-Allow-Origin 添加到您要启用cors 的域中。 response.setHeaders 非常适合这项任务。

另外需要注意的是 connect 没有办法处理路由。如果您的应用程序需要不同的路由,那么您可能必须为每个路由编写逻辑,并将 res 标头添加到要启用 cors 的那些标头。你可以使用req.url

var http = require("http");
var connect = require('connect');

var app = connect()

    .use(connect.logger('dev'))

    .use(connect.static('home'))

    .use(function(req, res)

    res.setHeader("Access-Control-Allow-Origin", "http://example.com");
    res.end('hello world\n');

 );

var server = http.createServer(app);

server.listen(9999, function () 

    console.log('server is listening');
);

这是我在 chrome 开发工具中得到的响应

HTTP/1.1 200 OK
Access-Control-Allow-Origin: http://example.com
Date: Sat, 15 Jun 2013 16:01:59 GMT
Connection: keep-alive
Transfer-Encoding: chunked

【讨论】:

非常感谢,绝对完美!【参考方案2】:

我希望这会有所帮助:

//CORS middleware
var allowCrossDomain = function(req, res, next) 
    res.header('Access-Control-Allow-Origin', config.allowedDomains);
    res.header('Access-Control-Allow-Methods', 'GET,PUT,POST,DELETE');
    res.header('Access-Control-Allow-Headers', 'Content-Type');

    next();


//...
app.configure(function() 

    app.use(allowCrossDomain);
    app.use(express.static(__dirname + '/public'));
);

更多细节: How to allow CORS?

【讨论】:

res.header 必须是 res.setHeader 用于连接中间件 2.0 及更高版本【参考方案3】:

express.static 接受一个配置对象。您可以提供属性 setHeaders 并通过该函数设置响应的标头:

    app.use(express.static('public', 
      setHeaders: function setHeaders(res, path, stat) 
        res.header('Access-Control-Allow-Origin', '*');
        res.header('Access-Control-Allow-Methods', 'GET');
        res.header('Access-Control-Allow-Headers', 'Content-Type');
      
    ))

这个函数的参数是:

res,响应对象。 path,正在发送的文件路径。 stat,正在发送的文件的统计对象。

我希望该请求在此处可用,以便我可以根据 Origin 标头有条件地设置 CORS 标头。

【讨论】:

【参考方案4】:

如果您使用 gulp,最简单的方法是使用名为“gulp-connect”和“connect-modrewrite”的 gulp 插件,并定义一个新的 gulptask 来重定向特定的 api。 这是为了让 apache 充当特定 api 的代理,绕过飞行前请求,以避免 CORs 问题。 我使用以下 gulp 任务来解决这个问题。

var connect = require('gulp-connect'),
    modRewrite = require('connect-modrewrite');
/**
* Proxy Config
*/
gulp.task('connect', function () 
  connect.server(
    root: ['./.tmp', './.tmp/folderLocations', './src', './bower_components'],
    port: 9000,
    livereload: true,
    middleware: function (connect, opt) 
      return [
        modRewrite([
          '^/loginProxy/(.*)$ http://app.xyzdomain.com/service/login/auth/$1 [P]'
        ])
      ];
    
  );
);

【讨论】:

以上是关于如何将 CORS-Headers 添加到静态连接服务器?的主要内容,如果未能解决你的问题,请参考以下文章

即使在安装 cors-headers 之后,Django cors 也会出错

如何添加预编译静态库 libwebrtc

如何将静态页面添加到WordPress?

PHP如何隐藏静态网页的真实地址及下载文件的绝对路径

如何将核心数据添加到 iOS 的静态框架?

如何将对象添加到静态数组中