diff options
Diffstat (limited to 'files/ja/learn')
-rw-r--r-- | files/ja/learn/server-side/node_server_without_framework/index.html | 28 |
1 files changed, 20 insertions, 8 deletions
diff --git a/files/ja/learn/server-side/node_server_without_framework/index.html b/files/ja/learn/server-side/node_server_without_framework/index.html index a59228be80..13d633d616 100644 --- a/files/ja/learn/server-side/node_server_without_framework/index.html +++ b/files/ja/learn/server-side/node_server_without_framework/index.html @@ -43,20 +43,21 @@ http.createServer(function (request, response) { var extname = String(path.extname(filePath)).toLowerCase(); var mimeTypes = { - '.html': 'text/html', + '.html': 'text/html', '.js': 'text/javascript', '.css': 'text/css', '.json': 'application/json', '.png': 'image/png', '.jpg': 'image/jpg', '.gif': 'image/gif', + '.svg': 'image/svg+xml', '.wav': 'audio/wav', '.mp4': 'video/mp4', '.woff': 'application/font-woff', '.ttf': 'application/font-ttf', '.eot': 'application/vnd.ms-fontobject', '.otf': 'application/font-otf', - '.svg': 'application/image/svg+xml' + '.wasm': 'application/wasm' }; var contentType = mimeTypes[extname] || 'application/octet-stream'; @@ -72,7 +73,6 @@ http.createServer(function (request, response) { else { response.writeHead(500); response.end('Sorry, check with the site admin for error: '+error.code+' ..\n'); - response.end(); } } else { @@ -98,11 +98,13 @@ var path = require('path'); <pre class="brush: js language-js">http.createServer(function (request, response) { ... }).listen(8125); +console.log('Server running at http://127.0.0.1:8125/'); </pre> <p>次の4行では、要求があったURLから、ファイルへのパスを決定します。ファイル名が明示されていないときは、デフォルト名を使うようにします。</p> -<pre class="brush: js">var filePath = '.' + request.url; +<pre class="brush: js">console.log('request ', request.url); +var filePath = '.' + request.url; if (filePath == './') { filePath = './index.html'; } @@ -112,7 +114,8 @@ if (filePath == './') { <p>次に、要求されたファイルの拡張子を調べ、以下に定義する<a href="/ja/docs/Web/HTTP/Basics_of_HTTP/MIME_types">MIMEタイプ</a>のどれかと一致したら、そのタイプを使います。一致しない場合には、デフォルトのタイプ<code>application/octet-stream</code>を使うようにします。.</p> -<pre class="brush: js">var mimeTypes = { +<pre class="brush: js">var extname = String(path.extname(filePath)).toLowerCase(); +var mimeTypes = { '.html': 'text/html', '.js': 'text/javascript', '.css': 'text/css', @@ -120,13 +123,14 @@ if (filePath == './') { '.png': 'image/png', '.jpg': 'image/jpg', '.gif': 'image/gif', + '.svg': 'image/svg+xml', '.wav': 'audio/wav', '.mp4': 'video/mp4', '.woff': 'application/font-woff', '.ttf': 'application/font-ttf', '.eot': 'application/vnd.ms-fontobject', '.otf': 'application/font-otf', - '.svg': 'application/image/svg+xml' + '.wasm': 'application/wasm' }; var contentType = mimeTypes[extname] || 'application/octet-stream'; @@ -139,7 +143,16 @@ var contentType = mimeTypes[extname] || 'application/octet-stream'; }); </pre> -<p>関数のなかで最初にやることは、起こりうるエラーへの対応です。一番多いのは、存在しないファイルを要求された場合(<code>ENOENT</code>)で、エラーコード404に対応するページを返してやります。</p> +<p>関数のなかで最初にやることは、起こりうるエラーへの対応です。</p> + +<pre class="brush: js">if (error) { + .. +} else { + .. +} +</pre> + +<p>一番多いのは、存在しないファイルを要求された場合(<code>ENOENT</code>)で、エラーコード404に対応するページを返してやります。</p> <pre class="brush: js">if(error.code == 'ENOENT') { fs.readFile('./404.html', function(error, content) { @@ -150,7 +163,6 @@ var contentType = mimeTypes[extname] || 'application/octet-stream'; else { response.writeHead(500); response.end('Sorry, check with the site admin for error: '+error.code+' ..\n'); - response.end(); }</pre> <p>何もエラーが検出されなかったら、MIME型をヘッダーに付けて、要求されたファイルを返してやります。</p> |