问题
I have installed http-server globally.
I launch it from myDir on localhost port 8080. In myDir I have index.html.
If I request (from the browser) http://localhost:8080/ I get index.html, which is OK.
If I request though http://localhost:8080/anything I do not get any response from the server. 
What I would like, on the contrary, is that my server always responds with index.html to any http request reaching localhost on port 8080.
Is this possible.
Thanks in advance
回答1:
Simple and straight-forward example using Express 4.x:
var express = require('express');
var app = express();
var path = __dirname + '/public';
var port = 8080;
app.use(express.static(path));
app.get('*', function(req, res) {
    res.sendFile(path + '/index.html');
});
app.listen(port);
This implementation will always respond with index.html if the requested file is not found, and it's almost as simple as using http-server, which lacks this option.
回答2:
To achieve what you are asking for, I recommend you live-server instead of http-server.
live-server --port=8080 --entry-file=./index.html
live-server is also providing a hot-reload but it was not one of your request
Edit: live-server is not designed to be used in production. No gzip compression for example
Edit 2: The maintainer of http-server clearly said in this comment that never, http-server will consider the SPA use-cases
Edit 3: serve seems to be a good option too
回答3:
Yes there is, with the -P/--proxy option:
http-server -P http://localhost:8080/
Note that any error, 404 included, will redirect to your index, not just missing path.
回答4:
Sometimes for specific cases like this one, it's easy enough to write your own server:
'use strict';
var host = '127.0.0.1', port = 3333;
var path = require('path');
var app = require('express')();
app.get('*', (req, res) => res.sendFile(path.join(__dirname, 'index.html')));
app.listen(port, () => console.log(`Listening on http://${host}:${port}/`));
But keep in mind that if every path returns index.html then in the index.html you cannot reference anything like images, style sheets or client side JavaScript files. Not only with the code shown above but with any solution that sends the same response (index.html) to every request.
You may need to make some exceptions and it's not hard with Express:
'use strict';
var host = '127.0.0.1', port = 3333;
var path = require('path');
var app = require('express')();
app.get('/x.png', (req, res) => res.sendFile(path.join(__dirname, 'x.png')));
app.get('*', (req, res) => res.sendFile(path.join(__dirname, 'index.html')));
app.listen(port, () => console.log(`Listening on http://${host}:${port}/`));
Just keep in mind that the exceptions have to go to the top because the first matching route will be used for a given request.
Of course you need to save this code e.g. to app.js, install Express:
npm install express
and start it with:
node app.js
It's more complicated than using a ready solution (though, as you can see, not that complicated either) but you have much more flexibility in how exactly you want it to behave. It's also easy to add logging etc.
来源:https://stackoverflow.com/questions/39744309/node-http-server-to-respond-with-index-html-to-any-request