0

0

nodejs搭建web网站

WBOY

WBOY

发布时间:2023-05-11 22:18:35

|

1782人浏览过

|

来源于php中文网

原创

随着web技术的不断发展,node.js已成为人们广泛使用的开发语言之一。node.js是一种基于chrome v8引擎的javascript运行环境,适用于构建快速、可扩展的网络应用程序。在本文中,我们将介绍如何使用node.js建立一个web网站的过程。

一、环境搭建

在开始之前,需要先进行环境搭建。推荐使用LTS版本的Node.js,在官网(https://nodejs.org/en/)下载对应系统的安装包,并进行安装。

安装完成后,需确认Node.js的环境变量是否配置成功。打开命令行窗口,输入node -v,如果出现版本号,证明安装成功。

二、搭建HTTP服务器

Node.js提供了http模块,可以通过这个模块创建一个Web服务器。其中,createServer()方法创建HTTP服务器,listen()方法监听指定的端口和IP地址。

代码如下:

const http = require('http');

const hostname = '127.0.0.1';
const port = 3000;

const server = http.createServer((req, res) => {
    res.statusCode = 200;
    res.setHeader('Content-Type', 'text/plain');
    res.end('Hello World!
');
});

server.listen(port, hostname, () => {
    console.log(`Server running at http://${hostname}:${port}/`);
});

以上代码创建了一个简单的HTTP服务器,监听本机3000端口。在浏览器中输入http://127.0.0.1:3000/,即可访问该服务器上的页面。页面内容为Hello World!。

三、处理路由

如果只是简单的向客户端发送Hello World!消息,那么使用HTTP服务器就已经足够了。但是实际开发中,会遇到更加复杂的请求响应场景,需要处理路由。

本例中,假设有两个页面:/home 和/about。当请求访问这两个页面时,需要进行不同的处理。因此,可以在HTTP服务器中添加路由处理。

代码如下:

const http = require('http');
const url = require('url');

const hostname = '127.0.0.1';
const port = 3000;

const server = http.createServer((req, res) => {
    const uri = url.parse(req.url).pathname;
    if (uri === '/home') {
        res.statusCode = 200;
        res.setHeader('Content-Type', 'text/plain');
        res.end('Welcome to the homepage!
');
    } else if (uri === '/about') {
        res.statusCode = 200;
        res.setHeader('Content-Type', 'text/plain');
        res.end('About the website!
');
    } else {
        res.statusCode = 404;
        res.setHeader('Content-Type', 'text/plain');
        res.end('404 Not Found
');
    }
});

server.listen(port, hostname, () => {
    console.log(`Server running at http://${hostname}:${port}/`);
});

以上代码中,使用了Node.js内置的url模块,将请求的url地址解析为pathname,用于路由处理。当请求的pathname为/home时,服务器返回“Welcome to the homepage!”;当请求的pathname为/about时,服务器返回“About the website!”;当请求的pathname不存在时,服务器返回404 Not Found。

酷潮旅游网站管理系统
酷潮旅游网站管理系统

酷潮旅游网站管理系统是最新开发的一套旅游行业网站管理系统,有效的帮助您搭建旅游电子商务网站。系统包含了文章发布模块、酒店模块、机票模块、旅游度假模块、景点模块、图片模块、旅游商城模块、会员模块、预订及订单处理模块 功能模块后台用户名密码:admin

下载

四、使用模板引擎

在实际开发过程中,使用模板引擎可以极大地提高开发效率。常用的模板引擎有ejs、handlebars、jade等。本例中,使用ejs模板引擎进行页面渲染。

首先,通过npm安装ejs模块:

npm install ejs --save

在HTTP服务器中进行修改,使用模板引擎渲染HTML页面:

const http = require('http');
const url = require('url');
const ejs = require('ejs');
const fs = require('fs');

const hostname = '127.0.0.1';
const port = 3000;

const server = http.createServer((req, res) => {
    const uri = url.parse(req.url).pathname;

    if (uri === '/home') {
        fs.readFile('./views/home.ejs', 'utf8', (err, data) => {
            if (err) {
                console.log(err);
                res.statusCode = 404;
                res.setHeader('Content-Type', 'text/plain');
                res.end('File not found!
');
            } else {
                res.statusCode = 200;
                res.setHeader('Content-Type', 'text/html');
                const template = ejs.compile(data);
                const html = template({title: 'Home Page', message: 'Welcome to the homepage!'});
                res.end(html);
            }
        });
    } else if (uri === '/about') {
        fs.readFile('./views/about.ejs', 'utf8', (err, data) => {
            if (err) {
                console.log(err);
                res.statusCode = 404;
                res.setHeader('Content-Type', 'text/plain');
                res.end('File not found!
');
            } else {
                res.statusCode = 200;
                res.setHeader('Content-Type', 'text/html');
                const template = ejs.compile(data);
                const html = template({title: 'About Page', message: 'About the website!'});
                res.end(html);
            }
        });
    } else {
        res.statusCode = 404;
        res.setHeader('Content-Type', 'text/plain');
        res.end('404 Not Found
');
    }
});

server.listen(port, hostname, () => {
    console.log(`Server running at http://${hostname}:${port}/`);
});

以上代码中,使用了fs模块读取模板文件,使用ejs模块渲染模板文件,将生成的HTML页面返回给客户端。

五、使用静态文件

在实际开发中,通常会使用到静态文件,如图片、CSS文件、JavaScript文件等。Node.js提供了静态文件服务,可以用于处理静态文件的请求。

代码如下:

const http = require('http');
const url = require('url');
const ejs = require('ejs');
const fs = require('fs');
const path = require('path');

const hostname = '127.0.0.1';
const port = 3000;

const server = http.createServer((req, res) => {
    const uri = url.parse(req.url).pathname;
    const filename = path.join(process.cwd(), uri);

    fs.exists(filename, (exists) => {
        if (!exists) {
            res.statusCode = 404;
            res.setHeader('Content-Type', 'text/plain');
            res.end('404 Not Found
');
            return;
        }

        if (fs.statSync(filename).isDirectory()) {
            filename += '/index.html';
        }

        fs.readFile(filename, 'binary', (err, file) => {
            if (err) {
                res.statusCode = 500;
                res.setHeader('Content-Type', 'text/plain');
                res.end(err + '
');
                return;
            }

            res.statusCode = 200;
            const extname = path.extname(filename);
            res.setHeader('Content-Type', mimeTypes[extname] || 'text/plain');
            res.write(file, 'binary');
            res.end();
        });
    });
});

server.listen(port, hostname, () => {
    console.log(`Server running at http://${hostname}:${port}/`);
});

以上代码中,使用fs模块判断请求的文件是否存在,使用path模块处理路径,使用mimeTypes定义文件类型。如果请求的文件不存在,则返回404 Not Found;如果请求的是文件夹,则默认请求文件夹中的index.html文件;如果文件读取成功,则返回200,同时设置Content-Type头和响应体。

通过以上的操作,我们就成功地使用Node.js搭建了一个Web网站,实现了基本的路由处理和静态文件服务。通过更进一步的学习和实践,我们可以做出更加复杂的Web网站,并实现更多的功能,如数据库操作、请求代理等。

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

相关专题

更多
c++ 根号
c++ 根号

本专题整合了c++根号相关教程,阅读专题下面的文章了解更多详细内容。

57

2026.01.23

c++空格相关教程合集
c++空格相关教程合集

本专题整合了c++空格相关教程,阅读专题下面的文章了解更多详细内容。

57

2026.01.23

yy漫画官方登录入口地址合集
yy漫画官方登录入口地址合集

本专题整合了yy漫画入口相关合集,阅读专题下面的文章了解更多详细内容。

237

2026.01.23

漫蛙最新入口地址汇总2026
漫蛙最新入口地址汇总2026

本专题整合了漫蛙最新入口地址大全,阅读专题下面的文章了解更多详细内容。

393

2026.01.23

C++ 高级模板编程与元编程
C++ 高级模板编程与元编程

本专题深入讲解 C++ 中的高级模板编程与元编程技术,涵盖模板特化、SFINAE、模板递归、类型萃取、编译时常量与计算、C++17 的折叠表达式与变长模板参数等。通过多个实际示例,帮助开发者掌握 如何利用 C++ 模板机制编写高效、可扩展的通用代码,并提升代码的灵活性与性能。

17

2026.01.23

php远程文件教程合集
php远程文件教程合集

本专题整合了php远程文件相关教程,阅读专题下面的文章了解更多详细内容。

103

2026.01.22

PHP后端开发相关内容汇总
PHP后端开发相关内容汇总

本专题整合了PHP后端开发相关内容,阅读专题下面的文章了解更多详细内容。

73

2026.01.22

php会话教程合集
php会话教程合集

本专题整合了php会话教程相关合集,阅读专题下面的文章了解更多详细内容。

81

2026.01.22

宝塔PHP8.4相关教程汇总
宝塔PHP8.4相关教程汇总

本专题整合了宝塔PHP8.4相关教程,阅读专题下面的文章了解更多详细内容。

70

2026.01.22

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号