この要点を確認してください。参考までにここに再掲しますが、要点は定期的に更新されています。
Node.JS 静的ファイル Web サーバー。任意のディレクトリでサーバーを起動するためにパスに入れてください。オプションのポート引数を取ります。
var http = require("http"),
url = require("url"),
path = require("path"),
fs = require("fs"),
port = process.argv[2] || 8888;
http.createServer(function(request, response) {
var uri = url.parse(request.url).pathname
, filename = path.join(process.cwd(), uri);
fs.exists(filename, function(exists) {
if(!exists) {
response.writeHead(404, {"Content-Type": "text/plain"});
response.write("404 Not Found\n");
response.end();
return;
}
if (fs.statSync(filename).isDirectory()) filename += '/index.html';
fs.readFile(filename, "binary", function(err, file) {
if(err) {
response.writeHead(500, {"Content-Type": "text/plain"});
response.write(err + "\n");
response.end();
return;
}
response.writeHead(200);
response.write(file, "binary");
response.end();
});
});
}).listen(parseInt(port, 10));
console.log("Static file server running at\n => http://localhost:" + port + "/\nCTRL + C to shutdown");
アップデート
Gist は css および js ファイルを処理します。私はそれを自分で使用しました。「バイナリ」モードで読み取り/書き込みを使用しても問題ありません。これは、ファイルがファイル ライブラリによってテキストとして解釈されず、応答で返される content-type とは無関係であることを意味します。
コードの問題は、常に「text/plain」のコンテンツ タイプを返すことです。上記のコードは content-type を返しませんが、HTML、CSS、および JS にのみ使用している場合、ブラウザーはそれらを適切に推測できます。間違ったものほど優れたコンテンツ タイプはありません。
通常、コンテンツ タイプは Web サーバーの構成です。これで問題が解決しない場合は申し訳ありませんが、単純な開発サーバーとして機能し、他の人に役立つかもしれないと考えました. 応答で正しいコンテンツ タイプが必要な場合は、joeytwiddle のように明示的に定義するか、適切なデフォルトを持つ Connect などのライブラリを使用する必要があります。これの良いところは、シンプルで自己完結型 (依存関係がない) ことです。
しかし、私はあなたの問題を感じています。したがって、これが複合ソリューションです。
var http = require("http"),
url = require("url"),
path = require("path"),
fs = require("fs")
port = process.argv[2] || 8888;
http.createServer(function(request, response) {
var uri = url.parse(request.url).pathname
, filename = path.join(process.cwd(), uri);
var contentTypesByExtension = {
'.html': "text/html",
'.css': "text/css",
'.js': "text/javascript"
};
fs.exists(filename, function(exists) {
if(!exists) {
response.writeHead(404, {"Content-Type": "text/plain"});
response.write("404 Not Found\n");
response.end();
return;
}
if (fs.statSync(filename).isDirectory()) filename += '/index.html';
fs.readFile(filename, "binary", function(err, file) {
if(err) {
response.writeHead(500, {"Content-Type": "text/plain"});
response.write(err + "\n");
response.end();
return;
}
var headers = {};
var contentType = contentTypesByExtension[path.extname(filename)];
if (contentType) headers["Content-Type"] = contentType;
response.writeHead(200, headers);
response.write(file, "binary");
response.end();
});
});
}).listen(parseInt(port, 10));
console.log("Static file server running at\n => http://localhost:" + port + "/\nCTRL + C to shutdown");