I have a few static pages served with Express.JS. The setup is easy:
var app = express();
app.configure(function(){
app.use(express.static(path.join(application_root, "StaticPages")));
app.use(express.errorHandler({ dumpExceptions: true, showStack: true }));
});
I want the response to include an addittional http header (Access-Control-Allow-Origin:*). Where should it be placed?
I tried the below sample, but of course the header appears only on the default page:
app.get('/', function(req, res){
res.setHeader("Access-Control-Allow-Origin", "*");
res.send('Hello World');
});
Thanks.
Yes, that is because you defined it just for the
GET /route and not for the other paths. You should use a middleware instead.If you wish to set the header for all requests:
If you just want to do it for the static folders, there is no general method. You can probably change the express.static(which comes from connect.static). Another way to do it is to match urls and set the header if the url is matched.
NOTE: that the middleware need to be before the routes to make effect, in other words you can’t put the middleware after the static middleware.