I am writing a little demo web server delivering static html,css and javascript. The server looks like
(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');
});
})();
My client side javascript makes ajax calls to a different server. How can I add
Access-Control-Allow-Origin: http://example.com
to my server response, so that the client side javascript can do the ajax call?
Had a bit of trouble figuring this one out since express has spoiled me.
Take a look at enable cors. Basically what you need to be doing is add
Access-Control-Allow-Origin
to the domain you want to enable cors on. response.setHeaders is perfect for this task.Another thing to note is that connect has no way to handle routes. If your app needs to have different routes then you will probably have to write logic for each of them and add res headers to the ones on which you want to enable cors. You can use
req.url
for it.This is the response I got in chrome dev tools
The easiest method, if you are using gulp would be to use gulp plugin called "gulp-connect" and "connect-modrewrite" and define a new gulptask to redirect a particular api. This is to make the apache act as a Proxy for the particular api, to bypass the pre-flight request, inorder to avoid CORs issue. I used the following gulp task to overcome this problem.
express.static
takes a configuration object. You can provide the propertysetHeaders
and from that function you can set headers for the response:The parameters to this function are:
res
, the response object.path
, the file path that is being sent.stat
, the stat object of the file that is being sent.I wish that the request were available here so that I could conditionally set the CORS headers based upon the
Origin
header.I hope this will help:
More detail: How to allow CORS?