从零开始,在windows上用nodejs搭建一个静态文件服务器

时间:2022-09-01 13:05:15

从零开始,在windows上用nodejs搭建一个静态文件服务器

首先安装nodejs:

  • 新建一个node文件夹
  • 下载node.exe到该文件夹
  • 下载npm然后解压到该文件夹
  • 现在node文件夹是这样的从零开始,在windows上用nodejs搭建一个静态文件服务器
  • 把该目录加入到path环境变量
  • 在命令行执行
    node -v
    
    npm -v
    

    如果得到了版本号则表示nodejs安装完成

  • 在命令行中执行
    npm config set registry https://registry.npm.taobao.org
    

    以后安装nodejs模块 都会从淘宝的npm镜像中下载

  • 如果想要发布自己的模块到npm要先把npm的registry切换回来
    npm config set registry https://registry.npmjs.org
    

接下来搭建静态文件服务器

  • 创建一个文件夹server,一个文件夹root,server内是服务器的js代码,root是根目录
  • server文件夹里面创建js文件 index.js mime.js server.js
  • index.js
    var server = require('./server.js');
    var cp = require('child_process');
    var rootpath = 'root';
    var sv = server.create({
    port: '9587',
    host: '127.0.0.1',
    root: rootpath
    });
    cp.exec('explorer http://127.0.0.1:9587', function () {
    });

      

  • mime.js
    var types = {
    "css": "text/css",
    "less": "text/css",
    "gif": "image/gif",
    "html": "text/html",
    "ejs": "text/html",
    "ico": "image/x-icon",
    "jpeg": "image/jpeg",
    "jpg": "image/jpeg",
    "js": "text/javascript",
    "json": "application/json",
    "pdf": "application/pdf",
    "png": "image/png",
    "svg": "image/svg+xml",
    "swf": "application/x-shockwave-flash",
    "tiff": "image/tiff",
    "txt": "text/plain",
    "wav": "audio/x-wav",
    "wma": "audio/x-ms-wma",
    "wmv": "video/x-ms-wmv",
    "xml": "text/xml",
    "default": "text/plain"
    };
    module.exports = function (ext) {
    return types[ext] || 'text/plain'
    }
  • server.js
    var http = require('http');
    var path = require('path');
    var fs = require('fs');
    var url = require("url");
    var mime = require('./mime.js'); function getPromise(cbk) {
    return (new Promise(cbk));
    }
    exports.create = function (opts) {
    var root = opts.root;
    var sv = http.createServer(); function request(request, response) {
    var pathname = decodeURIComponent(url.parse(request.url).pathname);
    var realPath = path.resolve(path.join(root, pathname));//请求的实际路径
    getPromise(function (resolve, reject) {
    fs.exists(realPath, function (isExists) {//判断路径是否存在
    isExists ? resolve() : reject();
    });
    }).catch(function () {
    resWrite(response, '404', 'html', '<h1>404</h1>file or dir : <h3>' + pathname + '</h3>not found');
    }).then(function () {
    return getPromise(function (resolve, reject) {
    fs.stat(realPath, function (err, stat) {//判断路径是文件还是文件夹
    if (err) {
    reject(err);
    } else {
    resolve(stat);
    }
    })
    }).then(function (stat) {
    if (stat.isFile()) {//路径对应的是一个文件
    resFile(response, realPath);
    } else if (stat.isDirectory()) {//路径对应的是一个文件夹
    var defaultIndexPath = path.resolve(realPath, 'index.html');
    return getPromise(function (resolve, reject) {
    fs.exists(defaultIndexPath, function (isExists) {
    if (isExists) {//如果该文件夹内有index.html
    resolve(true);
    } else {//该文件夹内没有index.html 则 显示该文件夹的内容列表
    resolve(false);
    }
    })
    }).then(function (isExistsIndex) {
    if (isExistsIndex) {
    resFile(response, defaultIndexPath);
    } else {
    return getPromise(function (resolve, reject) {
    fs.readdir(realPath, function (err, list) {
    if (err) {
    reject(err);
    } else {
    resolve(list);
    }
    })
    }).then(function (list) {
    var pmlist = list.map(function (item) {
    return (new Promise(function (resolve, reject) {
    fs.stat(path.resolve(realPath, item), function (err, stat) {
    if (err) {
    console.error(err);
    resolve('');
    } else if (stat.isFile()) {
    resolve(`<li class="file"><a href="${item}">${item}</a></li>`);
    } else if (stat.isDirectory()) {
    resolve(`<li class="dir"><a href="${item}/">${item}</a></li>`);
    } else {
    resolve('');
    }
    })
    }));
    });
    Promise.all(pmlist).then(function (linkList) {
    var links = '<ul>';
    links += '<li class="dir"><a href="../">../</a></li>';
    links += linkList.join('');
    links += '</ul>';
    var dirPage = `
    <!doctype html>
    <html>
    <head>
    <meta charset="utf-8"/>
    <style>
    a{color:blue;text-decoration: none;}
    .dir a{color:orange}
    </style>
    </head>
    <body>
    ${links}
    </body>
    </html>
    `;
    resWrite(response, '200', 'html', dirPage);
    });
    }).catch(function (err) {
    resWrite(response, '500', 'default', err.toString());
    })
    }
    })
    } else {//既不是文件也不是文件夹
    resWrite(response, '404', 'html', '<h1>404</h1>file or dir : <h3>' + pathname + '</h3>not found');
    }
    }).catch(function (err) {
    resWrite(response, '500', 'default', err.toString());
    })
    })
    } sv.on('request', request);
    sv.listen(opts.port, opts.host);
    return sv;
    }; function resFile(response, realPath) {//输出一个文件
    fs.readFile(realPath, function (err, data) {
    if (err) {
    resWrite(response, '500', 'default', err.toString());
    } else {
    var ext = path.extname(realPath).toLocaleLowerCase();
    ext = (ext ? ext.slice(1) : 'unknown');
    resWrite(response, '200', ext, data);
    }
    });
    } function resWrite(response, statusCode, mimeKey, data) {
    response.writeHead(statusCode, {'Content-Type': mime(mimeKey)});
    response.end(data);
    }
  • 在server文件夹内按住shift按钮,鼠标右键点击文件夹内空白区域,点击在此处打开命令窗口,执行命令
    node index.js
    

从零开始,在windows上用nodejs搭建一个静态文件服务器的更多相关文章

  1. 手把手教从零开始在GitHub上使用Hexo搭建博客教程&lpar;三&rpar;-使用Travis自动部署Hexo&lpar;1&rpar;

    前言 前面两篇文章介绍了在github上使用hexo搭建博客的基本环境和hexo相关参数设置等. 基于目前,博客基本上是可以完美运行了. 但是,有一点是不太好,就是源码同步问题,如果在不同的电脑上写文 ...

  2. 手把手教从零开始在GitHub上使用Hexo搭建博客教程&lpar;一&rpar;-附GitHub注册及配置

    前言 有朋友问了我关于博客系统搭建相关的问题,由于是做开发相关的工作,我给他推荐的是使用github的gh-pages服务搭建个人博客. 推荐理由: 免费:github提供gh-pages服务是免费的 ...

  3. 手把手教从零开始在GitHub上使用Hexo搭建博客教程&lpar;四&rpar;-使用Travis自动部署Hexo&lpar;2&rpar;

    前言 前面一篇文章介绍了Travis自动部署Hexo的常规使用教程,也是个人比较推荐的方法. 前文最后也提到了在Windows系统中可能会有一些小问题,为了在Windows系统中也可以实现使用Trav ...

  4. 手把手教从零开始在GitHub上使用Hexo搭建博客教程&lpar;二&rpar;-Hexo参数设置

    前言 前文手把手教从零开始在GitHub上使用Hexo搭建博客教程(一)-附GitHub注册及配置介绍了github注册.git相关设置以及hexo基本操作. 本文主要介绍一下hexo的常用参数设置. ...

  5. 用nodejs搭建一个简单的服务器

    使用nodejs搭建一个简单的服务器 nodejs优点:性能高(读写文件) 数据操作能力强 官网:www.nodejs.org 验证是否安装成功:cmd命令行中输入node -v 如果显示版本号表示安 ...

  6. windows上使用mkdocs搭建静态博客

    windows上使用mkdocs搭建静态博客 之前尝试过用HEXO搭建静态博客,最近发现有个叫mkdocs的开源项目也是搭建静态博客的好选择,而且它支持markdown格式,下面简要介绍一下mkdoc ...

  7. 利用 nodeJS 搭建一个简单的Web服务器(转)

    下面的代码演示如何利用 nodeJS 搭建一个简单的Web服务器: 1. 文件 WebServer.js: //-------------------------------------------- ...

  8. 利用git&plus;hugo&plus;markdown 搭建一个静态网站

    利用git+hugo+markdown 搭建一个静态网站 一直想要有一个自己的文档管理系统: 可以很方便书写,而且相应的文档很容易被分享 很方便的存储.管理.历史记录 比较方面的浏览和查询 第一点用M ...

  9. 用nodejs搭建一个简单的服务监听程序

    作为一个从业三年左右的,并且从事过半年左右PHP开发工作的前端,对于后台,尤其是对以js语言进行开发的nodejs,那是比较有兴趣的,虽然本身并没有接触过相关的工作,只是自己私下做的一下小实验,但是还 ...

随机推荐

  1. 常用原生JS方法总结(兼容性写法)

    经常会用到原生JS来写前端...但是原生JS的一些方法在适应各个浏览器的时候写法有的也不怎么一样的... 今天下班有点累... 就来总结一下简单的东西吧…… 备注:一下的方法都是包裹在一个EventU ...

  2. VS2012 集成 IL DASM IL微软中间语言查看器

    第一步: 找到IL DASM的安装位置,默认在C:\Program Files (x86)\Microsoft SDKs\Windows\v8.0A\bin\NETFX 4.0 Tools 第二步: ...

  3. linux下proc里关于磁盘性能的参数

    我 们在磁盘写操作持续繁忙的服务器上曾经碰到一个特殊的性能问题.每隔 30 秒,服务器就会遇到磁盘写活动高峰,导致请求处理延迟非常大(超过3秒).后来上网查了一下资料,通过调整内核参数,将写活动的高峰 ...

  4. 浅谈JavaScript计时器

    JavaScript计时器 1.什么是JavaScript计时器? 在JavaScript中,我们可以在设定的时间间隔之后来执行代码,而不是在函数被调用后立即执行. 2.计时器类型 一次性计时器:仅在 ...

  5. Dev gridControl 按回车增加一行

    将NewItemRowPosition属性设置为Top或Bottom, 在这样的新行中输入数据后,会自动添加到绑定的数据源中的, 如果你希望在按回车时焦点跳至下一列, 只需要设置GridView的Op ...

  6. 搭建yum仓库与定制rpm包

    笔者Q:972581034 交流群:605799367.有任何疑问可与笔者或加群交流 当我们自动化部署集群的时候,想要快速的安装所有服务,搭建yum仓库与定制rpm包是我们首先要做的 原创作品,转载请 ...

  7. 前端自动化测试神器-Katalon进阶用法

    前言 上一篇介绍了Katalon的基础用法,本篇继续介绍一些进阶的用法. Keyword 和 Method Call Statement Keyword Keyword就是自定义方法,该方法在当前项目 ...

  8. CSU OJ 1340 A Sample Problem

    Description My girlfriend loves 7 very much, she thinks it is lucky! If an integer contains one or m ...

  9. linux操作Mysql数据库基本命令

    1.显示数据库 show databases; 2.选择数据库 use 数据库名; 3.显示数据库中的表 show tables; 4.显示数据表的结构 describe 表名; 5.显示表中记录 S ...

  10. 20145334赵文豪网络对抗Web安全基础实践

    1.SQL注入攻击原理,如何防御? SQL注入攻击就是通过把SQL命令插入到Web表单递交或输入域名或页面请求的查询字符串,最终达到欺骗服务器执行恶意SQL命令的目的. 对于SQL注入攻击的防范,我觉 ...