ホームページ ウェブフロントエンド jsチュートリアル ノード静的ファイルサーバーインスタンスの詳細説明

ノード静的ファイルサーバーインスタンスの詳細説明

Mar 12, 2018 am 09:35 AM
node サーバ

この記事では、主に実用的なノード静的ファイル サーバーの例を紹介し、次にその機能をコードの形式で共有します。

サポートされている機能:

  1. 静的ファイルを読み取る

  2. ディレクトリにアクセスして、以下のindex.htmlファイルを自動的に検索します。index.htmlがない場合は、ファイルをリストします

  3. MIMEタイプのサポート

  4. cacheサポート/コントロールgzip圧縮サポート、ブレークポイントresumeglobalコマンド実行runing11

    まず http モジュールを導入し、サーバーを作成し、設定ポートをリッスンします:

     const http = require('http');
     
     const server = http.createServer();
     
     // 监听请求
     server.on('request', request.bind(this));
     
     server.listen(config.port, () => {
      console.log(`静态文件服务启动成功, 访问localhost:${config.port}`);
     });
    ログイン後にコピー
  5. 特にリクエストを処理し、静的ファイルを返すための fn を記述します。 URL モジュールはパスを取得します:
  6.  const url = require('url');
     const fs = require('fs');
     function request(req, res) {
     const { pathname } = url.parse(req.url); // 访问路径
     
     const filepath = path.join(config.root, pathname); // 文件路径
     
     fs.createReadStream(filepath).pipe(res); // 读取文件,并响应
     }
    ログイン後にコピー

    index.html の検索をサポートします:

     if (pathname === '/') {
      const rootPath = path.join(config.root, 'index.html');
      try{
       const indexStat = fs.statSync(rootPath);
       if (indexStat) {
        filepath = rootPath;
       }
      } catch(e) {
       
      }
     }
    ログイン後にコピー
  7. ディレクトリにアクセスするとき、列 出力ファイルディレクトリ:
  8.  fs.stat(filepath, (err, stats) => {
     if (err) {
      res.end('not found');
      return;
     }
     if (stats.isDirectory()) {
      let files = fs.readdirSync(filepath);
      files = files.map(file => ({
       name: file,
       url: path.join(pathname, file)
      }));
      let html = this.list()({
       title: pathname,
       files
      });
      res.setHeader('Content-Type', 'text/html');
      res.end(html);
     }
     }
    ログイン後にコピー

    htmlテンプレート:

     function list() {
      let tmpl = fs.readFileSync(path.resolve(__dirname, 'template', 'list.html'), 'utf8');
      return handlebars.compile(tmpl);
     }
    ログイン後にコピー
     <!DOCTYPE html>
     <html lang="en">
     <head>
     <meta charset="UTF-8">
     <meta name="viewport" content="width=device-width, initial-scale=1.0">
     <meta http-equiv="X-UA-Compatible" content="ie=edge">
     <title>{{title}}</title>
     </head>
     <body>
     <h1>hope-server静态文件服务器</h1>
     <ul>
      {{#each files}}
      <li>
       <a href={{url}}>{{name}}</a>
      </li>
      {{/each}}
     </ul>
     </body>
     </html>
    ログイン後にコピー
  9. 2.MIMEタイプサポート
  10. MIMEモジュールを使用してファイルタイプを取得し、エンコーディングを設定します:

    res.setHeader(&#39;Content-Type&#39;, mime.getType(filepath) + &#39;;charset=utf-8&#39;);
    ログイン後にコピー
  11. 3.キャッシュサポート
  12. http プロトコル キャッシュ:

  13. キャッシュ制御: http1.1 コンテンツ。データをキャッシュする方法とルールをクライアントに指示します。

private クライアントはキャッシュできます。

public クライアントとプロキシ サーバーの両方がキャッシュできます。

max-age=60 キャッシュされたコンテンツは 60 秒後に無効になります

no-cache 比較キャッシュを使用してデータを検証し、ソースサーバーに再度検証を強制する必要があります

no -store すべてのコンテンツはキャッシュされず、強制キャッシュも比較キャッシュもトリガーされません

    有効期限: http1.0 コンテンツ、キャッシュ制御はそれを上書きし、キャッシュの有効期限がいつになるかをクライアントに通知します
  1. ETag:次回クライアントがリクエストするとき、if-none-match: etag 値をリクエストヘッダーに追加します

  2. Last-Modified: 次回クライアントがリクエストするとき、if-modified-since: Last を追加します。 - リクエスト ヘッダーの変更された値
  3.  handleCache(req, res, stats, hash) {
     // 当资源过期时, 客户端发现上一次请求资源,服务器有发送Last-Modified, 则再次请求时带上if-modified-since
     const ifModifiedSince = req.headers[&#39;if-modified-since&#39;];
     // 服务器发送了etag,客户端再次请求时用If-None-Match字段来询问是否过期
     const ifNoneMatch = req.headers[&#39;if-none-match&#39;];
     // http1.1内容 max-age=30 为强行缓存30秒 30秒内再次请求则用缓存 private 仅客户端缓存,代理服务器不可缓存
     res.setHeader(&#39;Cache-Control&#39;, &#39;private,max-age=30&#39;);
     // http1.0内容 作用与Cache-Control一致 告诉客户端什么时间,资源过期 优先级低于Cache-Control
     res.setHeader(&#39;Expires&#39;, new Date(Date.now() + 30 * 1000).toGMTString());
     // 设置ETag 根据内容生成的hash
     res.setHeader(&#39;ETag&#39;, hash);
     // 设置Last-Modified 文件最后修改时间
     const lastModified = stats.ctime.toGMTString();
     res.setHeader(&#39;Last-Modified&#39;, lastModified);
     
     // 判断ETag是否过期
     if (ifNoneMatch && ifNoneMatch != hash) {
      return false;
     }
     // 判断文件最后修改时间
     if (ifModifiedSince && ifModifiedSince != lastModified) {
      return false;
     }
     // 如果存在且相等,走缓存304
     if (ifNoneMatch || ifModifiedSince) {
      res.writeHead(304);
      res.end();
      return true;
     } else {
      return false;
     }
     }
    ログイン後にコピー

    4. 圧縮

    クライアントは、リクエスト ヘッダーで Accept-Encoding: gzip、deflate を介してコンテンツを送信し、サーバーはそれに基づいてコンテンツを圧縮します。サポートされている圧縮形式。サーバーがサポートしていない場合、圧縮は実行されません。
  4.  getEncoding(req, res) {
      const acceptEncoding = req.headers[&#39;accept-encoding&#39;];
      // gzip和deflate压缩
      if (/\bgzip\b/.test(acceptEncoding)) {
       res.setHeader(&#39;Content-Encoding&#39;, &#39;gzip&#39;);
       return zlib.createGzip();
      } else if (/\bdeflate\b/.test(acceptEncoding)) {
       res.setHeader(&#39;Content-Encoding&#39;, &#39;deflate&#39;);
       return zlib.createDeflate();
      } else {
       return null;
      }
     }
    ログイン後にコピー
  5. 5. 再開可能なアップロード

    サーバーは、リクエスト ヘッダーの Range: bytes=0-xxx を使用して、Range リクエストを行っているかどうかを判断します。この値が存在し、有効である場合、ファイル コンテンツのリクエストされた部分のみが使用されます。応答ステータス コードは Partial Content を示す 206 になり、Content-Range が設定されます。無効な場合は、要求範囲が満たされないことを示す 416 ステータス コードが返されます。 Range リクエスト ヘッダーが含まれていない場合は、通常の方法で応答を続けます。
  6.  getStream(req, res, filepath, statObj) {
      let start = 0;
      let end = statObj.size - 1;
      const range = req.headers[&#39;range&#39;];
      if (range) {
       res.setHeader(&#39;Accept-Range&#39;, &#39;bytes&#39;);
       res.statusCode = 206;//返回整个内容的一块
       let result = range.match(/bytes=(\d*)-(\d*)/);
       if (result) {
        start = isNaN(result[1]) ? start : parseInt(result[1]);
        end = isNaN(result[2]) ? end : parseInt(result[2]) - 1;
       }
      }
      return fs.createReadStream(filepath, {
       start, end
      });
     }
    ログイン後にコピー
  7. 6. グローバル コマンドの実行

    npm リンクを通じて実行
  8. npm パッケージ ディレクトリのソフト リンクを作成し、それを {prefix}/lib/node_modules/

実行可能ファイル (bin 用に作成) にリンクします。 ) ソフトリンク、{prefix}/bin/{name} にリンクします

npm link コマンドは、ディレクトリと実行可能ファイルをリンクすることで、npm package コマンドをグローバルに実行可能にします。

package.jsonの設定

 {
 bin: {
 "hope-server": "bin/hope"
 }
 }
ログイン後にコピー

プロジェクトの下にbinディレクトリhopeファイルを作成し、yargsを使用してパラメータを渡すようにコマンドラインを設定します

 // 告诉电脑用node运行我的文件
 #! /usr/bin/env node
 
 const yargs = require(&#39;yargs&#39;);
 const init = require(&#39;../src/index.js&#39;);
 const argv = yargs.option(&#39;d&#39;, {
 alias: &#39;root&#39;,
 demand: &#39;false&#39;,
 type: &#39;string&#39;,
 default: process.cwd(),
 description: &#39;静态文件根目录&#39;
 }).option(&#39;o&#39;, {
 alias: &#39;host&#39;,
 demand: &#39;false&#39;,
 default: &#39;localhost&#39;,
 type: &#39;string&#39;,
 description: &#39;配置监听的主机&#39;
 }).option(&#39;p&#39;, {
 alias: &#39;port&#39;,
 demand: &#39;false&#39;,
 type: &#39;number&#39;,
 default: 8080,
 description: &#39;配置端口号&#39;
 }).option(&#39;c&#39;, {
 alias: &#39;child&#39;,
 demand: &#39;false&#39;,
 type: &#39;boolean&#39;,
 default: false,
 description: &#39;是否子进程运行&#39;
 })
 .usage(&#39;hope-server [options]&#39;)
 .example(
 &#39;hope-server -d / -p 9090 -o localhost&#39;, &#39;在本机的9090端口上监听客户端的请求&#39;
 ).help(&#39;h&#39;).argv;
 
 // 启动服务
 init(argv);
ログイン後にコピー

7. spawn

index.js

 const { spawn } = require(&#39;child_process&#39;);
 const Server = require(&#39;./hope&#39;);
 function init(argv) {
  // 如果配置为子进程开启服务
  if (argv.child) {
   //子进程启动服务
   const child = spawn(&#39;node&#39;, [&#39;hope.js&#39;, JSON.stringify(argv)], {
    cwd: __dirname,
    detached: true,
    stdio: &#39;inherit&#39;
   });
 
   //后台运行
   child.unref();
   //退出主线程,让子线程单独运行
   process.exit(0);
  } else {
   const server = new Server(argv);
   server.start();
  }
 }
 
 module.exports = init;
hope.js
 if (process.argv[2] && process.argv[2].startsWith(&#39;{&#39;)) {
 const argv = JSON.parse(process.argv[2]);
 const server = new Hope(argv);
 server.start();
 }
ログイン後にコピー

によって実装される子プロセスが実行中です

8. ソースコードとテスト

    ソースコードアドレス: Hope-server
  1. npm install hope-server -g
    ログイン後にコピー

    任意のディレクトリを入力

    hope-server
    ログイン後にコピー
  2. 関連する推奨事項:
  3. ノード静的ファイルサーバーの詳細な説明

を使用して書かれた単純なHTTP静的ファイルサーバーnodejs と Python

Node.js 静的ファイルサーバーの改良版 version_node.js

以上がノード静的ファイルサーバーインスタンスの詳細説明の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

AI Hentai Generator

AI Hentai Generator

AIヘンタイを無料で生成します。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

eMule検索がサーバーに接続できない問題の解決方法 eMule検索がサーバーに接続できない問題の解決方法 Jan 25, 2024 pm 02:45 PM

解決策: 1. eMule の設定をチェックして、正しいサーバー アドレスとポート番号が入力されていることを確認します; 2. ネットワーク接続を確認し、コンピューターがインターネットに接続されていることを確認し、ルーターをリセットします; 3. サーバーが正常に動作しているかどうかを確認します。ネットワーク接続に問題がない場合は、サーバーがオンラインであるかどうかを確認する必要があります; 4. eMule のバージョンを更新し、eMule 公式 Web サイトにアクセスし、eMule ソフトウェアの最新バージョンをダウンロードします。 5.助けを求めてください。

RPC サーバーに接続できない、およびデスクトップに入れない場合の解決策 RPC サーバーに接続できない、およびデスクトップに入れない場合の解決策 Feb 18, 2024 am 10:34 AM

RPC サーバーが利用できず、デスクトップからアクセスできない場合はどうすればよいですか? 近年、コンピューターとインターネットが私たちの生活の隅々に浸透しています。集中コンピューティングとリソース共有のテクノロジーとして、リモート プロシージャ コール (RPC) はネットワーク通信において重要な役割を果たします。ただし、場合によっては、RPC サーバーが利用できなくなり、デスクトップにアクセスできなくなる状況が発生することがあります。この記事では、この問題の考えられる原因のいくつかについて説明し、解決策を提供します。まず、RPC サーバーが使用できない理由を理解する必要があります。 RPCサーバーは、

CentOSインストールヒューズとCentOSインストールサーバーの詳細説明 CentOSインストールヒューズとCentOSインストールサーバーの詳細説明 Feb 13, 2024 pm 08:40 PM

LINUX ユーザーとして、CentOS にさまざまなソフトウェアやサーバーをインストールする必要があることがよくありますが、この記事では、CentOS に Fuse をインストールしてサーバーをセットアップする方法を詳しく紹介し、関連する作業をスムーズに完了できるようにします。 CentOS のインストールfusionFuse は、権限のないユーザーがカスタマイズされたファイル システムを通じてファイル システムにアクセスして操作できるようにするユーザー スペース ファイル システム フレームワークです。CentOS への Fuse のインストールは非常に簡単で、次の手順に従うだけです: 1. ターミナルを開き、次のようにログインします。ルートユーザー。 2. 次のコマンドを使用して、fuse パッケージをインストールします: ```yuminstallfuse3。インストール プロセス中のプロンプトを確認し、「y」を入力して続行します。 4. インストール完了

Dnsmasq を DHCP リレー サーバーとして構成する方法 Dnsmasq を DHCP リレー サーバーとして構成する方法 Mar 21, 2024 am 08:50 AM

DHCP リレーの役割は、2 つのサーバーが異なるサブネット上にある場合でも、受信した DHCP パケットをネットワーク上の別の DHCP サーバーに転送することです。 DHCP リレーを使用すると、ネットワーク センターに集中 DHCP サーバーを展開し、それを使用してすべてのネットワーク サブネット/VLAN に IP アドレスを動的に割り当てることができます。 Dnsmasq は、一般的に使用される DNS および DHCP プロトコル サーバーであり、ネットワーク内の動的ホスト構成の管理を支援する DHCP リレー サーバーとして構成できます。この記事では、dnsmasq を DHCP リレー サーバーとして構成する方法を説明します。コンテンツ トピック: ネットワーク トポロジ DHCP リレー上の静的 IP アドレスの構成 集中型 DHCP サーバー上の DHCP リレー D

PHP を使用して IP プロキシ サーバーを構築するためのベスト プラクティス ガイド PHP を使用して IP プロキシ サーバーを構築するためのベスト プラクティス ガイド Mar 11, 2024 am 08:36 AM

ネットワーク データ転送において、IP プロキシ サーバーは重要な役割を果たし、ユーザーが実際の IP アドレスを隠し、プライバシーを保護し、アクセス速度を向上させるのに役立ちます。この記事では、PHP を使用して IP プロキシ サーバーを構築する方法に関するベスト プラクティス ガイドを紹介し、具体的なコード例を示します。 IPプロキシサーバーとは何ですか? IP プロキシ サーバーは、ユーザーとターゲット サーバーの間にある中間サーバーであり、ユーザーとターゲット サーバー間の転送ステーションとして機能し、ユーザーのリクエストと応答を転送します。 IPプロキシサーバーを使用する場合

Epic サーバーがオフラインのときにゲームに参加できない場合はどうすればよいですか? Epic がオフラインでゲームに参加できない理由の解決策 Epic サーバーがオフラインのときにゲームに参加できない場合はどうすればよいですか? Epic がオフラインでゲームに参加できない理由の解決策 Mar 13, 2024 pm 04:40 PM

Epic サーバーがオフラインのときにゲームに参加できない場合はどうすればよいですか?この問題は多くの友人が経験しているはずです。このプロンプトが表示されると、正規のゲームが起動できなくなります。この問題は通常、ネットワークやセキュリティ ソフトウェアからの干渉によって引き起こされます。では、どのように解決すればよいでしょうか?今回の編集者が説明します。解決策を皆さんと共有したいと思います。今日のソフトウェア チュートリアルが問題の解決に役立つことを願っています。オフライン時に epic サーバーがゲームに参加できない場合の対処方法: 1. セキュリティ ソフトウェアによって妨害されている可能性があります。ゲーム プラットフォームとセキュリティ ソフトウェアを閉じて、再起動します。 2. 2 つ目は、ネットワークの変動が大きすぎることです。ルーターを再起動して機能するかどうかを確認してください。状態に問題がない場合は、5G モバイル ネットワークを使用して動作を試みることができます。 3. それならもっとあるかもしれない

PIノードティーチング:PIノードとは何ですか? PIノードをインストールしてセットアップする方法は? PIノードティーチング:PIノードとは何ですか? PIノードをインストールしてセットアップする方法は? Mar 05, 2025 pm 05:57 PM

ピン張りのノードの詳細な説明とインストールガイドこの記事では、ピネットワークのエコシステムを詳細に紹介します - PIノードは、ピン系生態系における重要な役割であり、設置と構成の完全な手順を提供します。 Pinetworkブロックチェーンテストネットワークの発売後、PIノードは多くの先駆者の重要な部分になり、テストに積極的に参加し、今後のメインネットワークリリースの準備をしています。まだピン張りのものがわからない場合は、ピコインとは何かを参照してください。リストの価格はいくらですか? PIの使用、マイニング、セキュリティ分析。パインワークとは何ですか?ピン競技プロジェクトは2019年に開始され、独占的な暗号通貨PIコインを所有しています。このプロジェクトは、誰もが参加できるものを作成することを目指しています

PHP FFmpeg 拡張機能をサーバーにインストールするにはどうすればよいですか? PHP FFmpeg 拡張機能をサーバーにインストールするにはどうすればよいですか? Mar 28, 2024 pm 02:39 PM

PHPFFmpeg拡張機能をサーバーにインストールするにはどうすればよいですか? PHPFFmpeg 拡張機能をサーバーにインストールすると、PHP プロジェクトでオーディオ ファイルとビデオ ファイルを処理し、オーディオ ファイルとビデオ ファイルのエンコード、デコード、編集、処理などの機能を実装できます。この記事では、PHPFFmpeg 拡張機能をサーバーにインストールする方法と、具体的なコード例を紹介します。まず、PHP と FFmpeg がサーバーにインストールされていることを確認する必要があります。 FFmpeg がインストールされていない場合は、以下の手順に従って FFmpe をインストールできます。

See all articles