ホームページ ウェブフロントエンド jsチュートリアル Node.jsでWebサーバーを構築する方法

Node.jsでWebサーバーを構築する方法

Jan 05, 2021 pm 05:45 PM
node.js ウェブサーバー

使用nodejs搭建Web服务器是学习Node.js比较全面的入门教程,因为实现Web服务器需要用到几个比较重要的模块:http模块、文件系统、url解析模块、路径解析模块、以及301重定向技术等,下面我们就一起来学习如何搭建一个简单的Web服务器。

Node.jsでWebサーバーを構築する方法

相关推荐:《nodejs 教程

作为一个Web服务器应具备以下几个功能:

  • 能显示以 .html/.htm 结尾的 Web 页面
  • 能直接打开以 .js/.css/.json/.text 结尾的文件内容
  • 显示图片资源
  • 自动下载以 .apk/.docx/.zip 结尾的文件
  • 形如 http://xxx.com/a/b/ ,  则查找b目录下是否有index.html, 如果有就显示,如果没有就列出该目录下的所有文件及文件夹,并可以进一步访问。
  • 形如 http://xxx.com/a/b,  则作301重定向到 http://xxx.com/a/b/ , 这样可以解决内部资源引用错位的问题。

引入需要用到的几个模块:

// http协议模块
var http = require('http');
// url解析模块
var url = require('url');
// 文件系统模块
var fs = require('fs');
// 路径解析模块
var path = require('path');
ログイン後にコピー

创建服务并在指定的端口监听:

// 创建一个服务
var httpServer = http.createServer(this.processRequest.bind(this));

// 在指定的端口监听服务
httpServer.listen(port, function() {
    console.log('[HttpServer][Start]', 'runing at http://' + ip + ':' + port + '/');
    console.timeEnd('[HttpServer][Start]');
});
ログイン後にコピー

在创建服务的时候需要传递一个匿名函数 processRequest 对请求进行处理,processRequest接收两个参数,分别是 request 和 response, request 对象中包含了请求的所有内容,response 是用来设置响应头以及对客户端做出响应操作。

processRequest: function (request, response) {
    varhasExt = true;
    varrequestUrl = request.url;
    varpathName = url.parse(requestUrl).pathname;
 
    // 对请求的路径进行解码,防止中文乱码
    pathName = decodeURI(pathName);
 
    // 如果路径中没有扩展名
    if(path.extname(pathName) === '') {
        // 如果不是以/结尾的,加/并作301重定向
        if(pathName.charAt(pathName.length-1) != '/'){
            pathName += '/';
            varredirect = 'http://'+ request.headers.host + pathName;
            response.writeHead(301, {
                location: redirect
            });
            response.end();
            return;
        }
        // 添加默认的访问页面,但这个页面不一定存在,后面会处理
        pathName += 'index.html';
        hasExt = false; // 标记默认页面是程序自动添加的
    }
 
    // 获取资源文件的相对路径
    varfilePath = path.join('http/webroot', pathName);
 
    // 获取对应文件的文档类型
    varcontentType = this.getContentType(filePath);
 
    // 如果文件名存在
    fs.exists(filePath, function(exists) {
        if(exists) {
            response.writeHead(200, {'content-type': contentType});
            varstream = fs.createReadStream(filePath, {flags: 'r', encoding: null});
            stream.on('error', function () {
                response.writeHead(500, {'content-type': 'text/html'});
                response.end(&#39;<h1>500 Server Error</h1>&#39;);
            });
            // 返回文件内容
            stream.pipe(response);
        } else{ // 文件名不存在的情况
            if(hasExt) {
                // 如果这个文件不是程序自动添加的,直接返回404
                response.writeHead(404, {&#39;content-type&#39;: &#39;text/html&#39;});
                response.end(&#39;<h1>404 Not Found</h1>&#39;);
            } else{
                // 如果文件是程序自动添加的且不存在,则表示用户希望访问的是该目录下的文件列表
                varhtml = "<head><meta charset=&#39;utf-8&#39;></head>";
                try{
                    // 用户访问目录
                    varfiledir = filePath.substring(0, filePath.lastIndexOf(&#39;\\&#39;));
                    // 获取用户访问路径下的文件列表
                    varfiles = fs.readdirSync(filedir);
                    // 将访问路径下的所以文件一一列举出来,并添加超链接,以便用户进一步访问
                    for(vari infiles) {
                        varfilename = files[i];
                        html += "<div><a  href=&#39;"+ filename + "&#39;>"+ filename + "</a></div>";
                    }
                } catch(e){
                    html += &#39;<h1>您访问的目录不存在</h1>&#39;;
                }
                response.writeHead(200, {&#39;content-type&#39;: &#39;text/html&#39;});
                response.end(html);
            }
        }
    });
}
ログイン後にコピー

请求处理函数中有几个重点需要说一下:

对于路径中有中文的,浏览器会自动进行编码(英文不变,中文会变),因此在接收到地址后,需要对地址进行解码,否则最后得到的路径和真实路径不相符,

当访问路径不是以具体的文件结尾,并且不是以/结尾,则需要通过重定向加上/,表示当前目录,否则当前路径下的静态资源会找不到。

如果访问路径是目录,则列出该目录下所有文件及文件夹,并可以点击访问,为了让中文目录能正常显示,则还要在header中设置charset=utf-8

核心代码就这么多,大概140行左右,完整的代码已上传到 github : https://github.com/git-onepixel/Node,  

如果要运行demo,打开 cmd 切换到根目录,运行 node start 即可。

如有问题,欢迎讨论!

更多编程相关知识,请访问:编程教学!!

以上がNode.jsでWebサーバーを構築する方法の詳細内容です。詳細については、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)

Nodeのメモリ制御に関する記事 Nodeのメモリ制御に関する記事 Apr 26, 2023 pm 05:37 PM

ノンブロッキングおよびイベント駆動に基づいて構築されたノード サービスには、メモリ消費量が少ないという利点があり、大量のネットワーク リクエストの処理に非常に適しています。大量のリクエストを前提として、「メモリ制御」に関する問題を考慮する必要があります。 1. V8 のガベージ コレクション メカニズムとメモリ制限 Js はガベージ コレクション マシンによって制御されます

CentOS上に構築されたWebサーバーのセキュリティ監査とイベントログ管理 CentOS上に構築されたWebサーバーのセキュリティ監査とイベントログ管理 Aug 05, 2023 pm 02:33 PM

CentOS で構築された Web サーバーのセキュリティ監査とイベント ログ管理の概要 インターネットの発展に伴い、Web サーバーのセキュリティ監査とイベント ログ管理の重要性が増しています。 CentOS オペレーティング システムで Web サーバーをセットアップした後は、サーバーのセキュリティに注意を払い、悪意のある攻撃からサーバーを保護する必要があります。この記事では、セキュリティ監査とイベント ログ管理を実行する方法を紹介し、関連するコード例を示します。セキュリティ監査 セキュリティ監査とは、サーバーのセキュリティ状態を包括的に監視および検査し、潜在的な問題を迅速に発見することを指します。

Node の File モジュールについて詳しく説明しましょう Node の File モジュールについて詳しく説明しましょう Apr 24, 2023 pm 05:49 PM

ファイル モジュールは、ファイルの読み取り/書き込み/開く/閉じる/削除の追加など、基礎となるファイル操作をカプセル化したものです。ファイル モジュールの最大の特徴は、すべてのメソッドが **同期** と ** の 2 つのバージョンを提供することです。 asynchronous**、sync サフィックスが付いているメソッドはすべて同期メソッドであり、持たないメソッドはすべて異種メソッドです。

ベスト プラクティス: CentOS で Web サーバーを構築するためのパフォーマンス チューニング ガイド ベスト プラクティス: CentOS で Web サーバーを構築するためのパフォーマンス チューニング ガイド Aug 04, 2023 pm 12:17 PM

ベスト プラクティス: CentOS で Web サーバーを構築するためのパフォーマンス チューニング ガイド 概要: この記事は、CentOS で Web サーバーを構築するユーザーにパフォーマンス チューニングのベスト プラクティスを提供し、サーバーのパフォーマンスと応答速度を向上させることを目的としています。いくつかの主要な調整パラメータと一般的に使用される最適化手法が紹介され、読者がこれらの手法をよりよく理解し、適用できるようにいくつかのサンプル コードが提供されます。 1. 不要なサービスを停止する CentOS 上で Web サーバーを構築すると、デフォルトで不要なサービスが起動され、システムリソースを占有します。

CentOS で Web サーバーを構築する前に注意する必要がある権限とアクセス制御戦略 CentOS で Web サーバーを構築する前に注意する必要がある権限とアクセス制御戦略 Aug 05, 2023 am 11:13 AM

CentOS で Web サーバーを構築する前に注意すべき権限とアクセス制御戦略 Web サーバーを構築するプロセスでは、権限とアクセス制御戦略が非常に重要です。権限とアクセス制御ポリシーを正しく設定すると、サーバーのセキュリティを保護し、権限のないユーザーによる機密データへのアクセスやサーバーの不適切な操作を防ぐことができます。この記事では、CentOS システムで Web サーバーを構築するときに注意する必要がある権限とアクセス制御戦略を紹介し、対応するコード例を示します。ユーザーとグループの管理 まず、専用の

ノードのバッファーについて詳しく見る ノードのバッファーについて詳しく見る Apr 25, 2023 pm 07:49 PM

当初、JS はブラウザ側でのみ動作していたため、Unicode でエンコードされた文字列の処理は簡単でしたが、バイナリ文字列や非 Unicode エンコード文字列の処理は困難でした。バイナリは、コンピュータのビデオ/オーディオ/プログラム/ネットワーク パッケージの最低レベルのデータ形式です。

入門チュートリアル: CentOS で Web サーバーをセットアップするためのクイック ガイド 入門チュートリアル: CentOS で Web サーバーをセットアップするためのクイック ガイド Aug 04, 2023 pm 06:04 PM

入門レベルのチュートリアル: CentOS で Web サーバーを構築するためのクイック ガイド はじめに: 今日のインターネット時代では、独自の Web サーバーを構築することが多くの人々にとって必要になっています。この記事では、CentOS オペレーティング システム上に Web サーバーを構築する方法を紹介し、読者がそれをすぐに実装できるようにコード例を示します。ステップ 1: Apache のインストールと構成 ターミナルを開き、次のコマンドを使用して Apache サーバーをインストールします: sudoyuminstallhttpd インストールが完了したら、Apac を起動します。

Go で Web サーバーを作成するためのベスト プラクティス Go で Web サーバーを作成するためのベスト プラクティス Jun 18, 2023 pm 07:38 PM

Go 言語は、特にネットワーク プログラミングで人気の開発言語となっています。 Go で Web サーバーを作成する場合、サーバーのセキュリティ、保守性、拡張性を確保するためのベスト プラクティスが数多くあります。ここでは、Go Web サーバーの効率と信頼性を向上させるのに役立ついくつかの提案と実践を示します。標準ライブラリの使用 Go 言語の標準ライブラリには、ネットワーク プログラミングに関連するパッケージが多数あります。たとえば、net/http パッケージは HTTP サーバーの作成に役立ち、net パッケージは低レベルのネットワーク接続の処理に役立ちます。

See all articles