Node.js开发手册(二)

简介: 版权声明:本文为博主chszs的原创文章,未经博主允许不得转载。 https://blog.csdn.net/chszs/article/details/8981859 Node.js开发手册(二)作者:chszs,转载需注明。
版权声明:本文为博主chszs的原创文章,未经博主允许不得转载。 https://blog.csdn.net/chszs/article/details/8981859

Node.js开发手册(二)

作者:chszs,转载需注明。博客主页: http://blog.csdn.net/chszs

一、静态文件服务

如果我们想把磁盘上的文件作为Web内容对外提供服务,那么怎么用Node来实现呢?答案是使用fs模块。
我们可以使用fs即filesystem模块载入文件的内容,并把内容通过createServer回调函数传递出去。提供静态文件服务是Node.js的核心基础功能,应该掌握它。

二、Demo

下面我们创建三个文件,这些文件都会由NodeJS提供静态文件服务。

1. index.html

内容如下:
<html>
    <head>
        <title>Yay Node!</title>
        <link rel="stylesheet" href="styles.css" type="text/css" />
        <script src="script.js" type="text/javascript"></script>
    </head>
    <body>
        <span id="yay">Yay!</span>
    </body>
</html>

2. script.js

内容如下:
// script.js
window.onload=function(){
    alert('Yay Node!');
};

3. styles.css

内容如下:
#yay{
    font-size: 5em;
    background: blue;
    color: yellow;
    padding: 0.5em;
}

将上面的三个文件放入content目录下。

4. 编写Node程序

创建名为server.js的脚本文件,内容如下:
var http = require('http');
var path = require('path');
var fs = require('fs');

http.createServer(function(req, res){
    var lookup = path.basename(decodeURI(req.url)) || 'index.html',
    f = 'content/' + lookup;
    fs.exists(f, function(exists){
        console.log(exists ? lookup + " is there" : lookup + " doesn't exist");
    });
}).listen(8080);

用supervisor热部署工具执行以上程序:
$ supervisor server.js

在浏览器访问地址:http://localhost:8080/foo
终端显示:
DEBUG: Starting child process with 'node server.js'
foo doesn't exist

在浏览器访问地址:http://localhost:8080/index.html
终端显示:
DEBUG: Starting child process with 'node server.js'
DEBUG: Watching directory '/home/chszs/tmp' for changes.
index.html is there

三、进阶

假定我们想让客户端知道文件的类型,可以通过扩展名进行判断。
修改server.js文件,内容为:
// server.js
var http = require('http');
var path = require('path');
var fs = require('fs');

var mimeTypes = {
    '.js': 'text/javascript',
    '.html': 'text/html',
    '.css': 'text/css'
};

http.createServer(function(req, res){
    var lookup = path.basename(decodeURI(req.url)) || 'index.html',
    f = 'content/' + lookup;
    fs.exists(f, function(exists){
        if(exists){
            fs.readFile(f, function(err, data){
                if(err){
                    res.writeHead(500);
                    res.end('Server Error!');
                    return;
                }
                var headers = {'Content-type': mimeTypes[path.extname]};
                res.writeHead(200, headers);
                res.end(data);
            });
            return;
        }
        res.writeHead(404);
        res.end();
    });
}).listen(8080);

在浏览器地址栏输入
http://localhost:8080/styles.css

http://localhost:8080/script.js
都会在网页上显示文件的内容。

在浏览器地址栏输入
http://localhost:8080/index.html
如图所示:



目录
相关文章
|
NoSQL JavaScript 数据库
Node.js开发手册(四)-Redis数据库访问
Node.js开发手册(四)-Redis数据库访问 因工作太忙,本系列的文章中断了很久,现在有机会继续了。 大家要记住,Node.js主要用于构建高性能、高可伸缩性的服务器和客户端应用,它面向的是“实时Web”。
1069 0
|
NoSQL JavaScript 数据库
Node.js开发手册(四)-Redis数据库访问
版权声明:本文为博主chszs的原创文章,未经博主允许不得转载。 https://blog.csdn.net/chszs/article/details/17660179 Node.js开发手册(四)-Redis数据库访问 作者:chszs,转载需注明。
879 0
|
JavaScript 前端开发 网络架构
Node.js开发手册(一)
一、Node.js简介 Node.js由于其简洁性而受到广泛关注。与PHP或ASP不同,后者在Web服务器和代码间没有间隔,也不需要自定义大量的配置文件。使用Node.js,我们可以创建服务器,自定义它,在代码层交付所有的内容。
1050 0
|
JavaScript 前端开发
Node.js开发手册(二)
一、静态文件服务 如果我们想把磁盘上的文件作为Web内容对外提供服务,那么怎么用Node来实现呢?答案是使用fs模块。我们可以使用fs即filesystem模块载入文件的内容,并把内容通过createServer回调函数传递出去。
897 0
|
JavaScript 网络架构 开发工具
Node.js开发手册(一)
版权声明:本文为博主chszs的原创文章,未经博主允许不得转载。 https://blog.csdn.net/chszs/article/details/8915944 Node.js开发手册(一) 作者:chszs,转载需注明。
1018 0
|
2月前
|
Web App开发 缓存 JavaScript
【安装指南】nodejs下载、安装与配置详细教程
这篇博文详细介绍了 Node.js 的下载、安装与配置过程,为初学者提供了清晰的指南。读者通过该教程可以轻松完成 Node.js 的安装,了解相关配置和基本操作。文章首先介绍了 Node.js 的背景和应用场景,随后详细说明了下载安装包、安装步骤以及配置环境变量的方法。作者用简洁明了的语言,配以步骤图示,使得读者能够轻松跟随教程完成操作。总的来说,这篇文章为初学者提供了一个友好的入门指南,使他们能够顺利开始使用 Node.js 进行开发。
196 1
【安装指南】nodejs下载、安装与配置详细教程
|
2月前
|
消息中间件 Web App开发 JavaScript
Node.js【简介、安装、运行 Node.js 脚本、事件循环、ES6 作业队列、Buffer(缓冲区)、Stream(流)】(一)-全面详解(学习总结---从入门到深化)
Node.js【简介、安装、运行 Node.js 脚本、事件循环、ES6 作业队列、Buffer(缓冲区)、Stream(流)】(一)-全面详解(学习总结---从入门到深化)
77 0
|
3月前
|
JavaScript 前端开发 API
Node.js【简介、安装、运行 Node.js 脚本、事件循环、ES6 作业队列、Buffer(缓冲区)、Stream(流)】(一)-全面详解(学习总结---从入门到深化)(下)
Node.js【简介、安装、运行 Node.js 脚本、事件循环、ES6 作业队列、Buffer(缓冲区)、Stream(流)】(一)-全面详解(学习总结---从入门到深化)
35 0
|
3月前
|
消息中间件 Web App开发 JavaScript
Node.js【简介、安装、运行 Node.js 脚本、事件循环、ES6 作业队列、Buffer(缓冲区)、Stream(流)】(一)-全面详解(学习总结---从入门到深化)(上)
Node.js【简介、安装、运行 Node.js 脚本、事件循环、ES6 作业队列、Buffer(缓冲区)、Stream(流)】(一)-全面详解(学习总结---从入门到深化)
42 0
|
19天前
|
JavaScript Windows
NodeJS 安装及环境配置
NodeJS 安装及环境配置