最近没事,学习了一下 node,仅仅是看看api,总是看了又忘,效率着实低下。

觉得 http-server 这个静态服务很神奇,突发奇想,自己也来实现这么一个静态服务试试。顺便巩固一下之前看过的API。暂且起名为 ks-server。

主要用到了node中的 http、fs、url、path、zlib、os等常用模块。

1. 初始化项目:

cd ks-server # cd 到我的项目中
yarn init -y

2. 将命令映射成全局命令

A、首先在 ks-server 根目录下新建 src 文件夹,再新建一个 bin/www.js 文件。

#! /usr/bin/env node
// 上面这句话,告诉命令行,我要用 node 环境来执行 www.js 这个文件
// www.js 文件
console.log('hello');

B、将如下代码添加到 package.json 中。

"bin": {
"ks-server": ".src/bin/www.js"
}

C、将 ks-server 命令映射成全局命令

npm link # 注意这个命令是在当前目录 ks-server 下运行的

出现 如下日志即表示成功!

3. 命令行参数处理

用 process.argv 来自己去解析命令行中的参数。但是我们在这儿用 commander 这个包来做参数处理。修改 www.js 文件为如下内容,测试 commander 包。

#! /usr/bin/env node

// www.js
const commander = require('commander');
const package = require('../package.json'); // 设置一个默认的值
let parser = {
port: 10086,
host: 'localhost',
dir: process.cwd() // 1. 为什么不能用 __dirname
}
// 监听一个 --help 事件,当用户输入 `ks-server --help` 时,会将一下内容追加到显示的后面。
// 这个绑定事件得放在 声明 argvs 之前
commander.on('--help', function () {
console.log("Usage:")
console.log(" ks-server -p 10086 --host localhost")
})
let argvs = commander
.version(package.version)
.option('-p,--port', 'server port')
.option('-o,--host', 'server hostname')
.option('-d,--dir', 'server dir')
.parse(process.argv); parser = { ...parser, ...argvs };
  1. 注意最后的 .parse(process.argv) 是不能少的。
  2. 绑定事件得放在声明 argvs 之前
  3. 事件绑定时,事件名不能是-h, --help,-h
解惑
  1. 为什么不能用 __dirname?

    __dirname 为当前被执行的js所在目录; process.cwd() 当前node命令所在的目录

4. 起一个静态服务

在 ks-server 目录下新建一个 server/index.js 文件。

const http = require('http');
const fs = require('fs');
const url = require('url');
const path = require('path'); // 第三方模块
const mime = require('mime');
const chalk = require('chalk'); // 粉笔
const debug = console.log;
const ejs = require('ejs'); // 模板 ejs、jade、handlebar

5. 实现逻辑

本来是想把代码贴过来的,发现也挺累的,还不如放到 github 上合适。/捂脸

https://github.com/MobroChu/ks-server

顺便给颗星星激励一下奋战在坚持与放弃边界线的菜鸟。项目有结构有所调整,es6诚然方便,单考虑到低版本node兼容性、低版本浏览器兼容行,故使用babel将es6语法解析成es5,并置于dist文件夹下。

6. 目录结构

目录在原有基础进行过优化,现在目录结构及其功能如下:

|-- dist 			// 打包后的代码
|-- bin // 命令解析相关文件
|-- www.js // 命令解析
|-- server // 静态服务
|-- server.js // 静态服务类文件
|-- node_modules // npm包
|-- src // es6 代码
|-- bin
|-- www.js
|--- server
|-- server.js
|-- static // 公共静态资源
|-- font // 字体图标
|-- logo // logo 图标
|-- template // 渲染模板
|-- template.html
|-- template.css
|-- template.js
|-- .babelrc
|-- .gitignore
|-- .npmignore
|-- package-lock.json
|-- package.json
|-- readme.md
|-- yarn.lock

你可知这百年爱人只能陪半途。 你且迷这风浪永远二十赶朝暮。 一一 记昨日书

实现一个类似 http-server 的静态服务 一一 ks-server的更多相关文章

  1. 如何使用 aph-cli 搭建本地静态开发环境(server + proxy + mock)

    前提资源 1.aph系统使用说明 2.aph-cli 使用说明 ================================== 一.如何使用aph-cli简单起一个服务 1.在APH管理系统注册 ...

  2. crtmp Server 开启rtsp服务功能

    Crtmp Server 包含了rtsp 服务功能,如果需要一个简单轻量的rtsp服务,Crtmp Server会是不错的选择. 默认情况下,rtsp功能是关闭的,需要在配置文件中打开.window环 ...

  3. (转)Nginx静态服务配置---详解root和alias指令

    Nginx静态服务配置---详解root和alias指令 原文:https://www.jianshu.com/p/4be0d5882ec5 静态文件 Nginx以其高性能著称,常用与做前端反向代理服 ...

  4. Nginx静态服务配置---详解root和alias指令

    Nginx静态服务配置---详解root和alias指令 静态文件 Nginx以其高性能著称,常用与做前端反向代理服务器.同时nginx也是一个高性能的静态文件服务器.通常都会把应用的静态文件使用ng ...

  5. 使用plupload做一个类似qq邮箱附件上传的效果

    公司项目中使用的框架是springmvc+hibernate+spring,目前需要做一个类似qq邮箱附件上传的功能,暂时只是上传小类型的附件 处理过程和解决方案都需要添加附件,处理过程和解决方案都可 ...

  6. [转]C#创建服务及使用程序自动安装服务,.NET创建一个即是可执行程序又是Windows服务的exe

    写在前面 原文地址:C#创建服务及使用程序自动安装服务,.NET创建一个即是可执行程序又是Windows服务的exe 这篇文章躺在我的收藏夹中有很长一段时间了,今天闲着没事,就自己动手实践了一下.感觉 ...

  7. Ubuntu Server搭建svn服务以及迁移方法【转】

    转自:http://www.linuxidc.com/Linux/2013-05/84693.htm Ubuntu Server搭建svn服务以及迁移方法 采用apache+svn,http访问方式. ...

  8. Amoeba是一个类似MySQL Proxy的分布式数据库中间代理层软件,是由陈思儒开发的一个开源的java项目

    http://www.cnblogs.com/xiaocen/p/3736095.html amoeba实现mysql读写分离 application  shang  2年前 (2013-03-28) ...

  9. HTTPS静态服务搭建过程详解

    HTTPS服务对于一个前端开发者来说是一个天天打招呼的老伙计了,但是之前我跟HTTPS打交道的场景一直是抓包,自己没有亲自搭建过HTTPS服务,对HTTPS的底层知识也是一知半解.最近正好遇到一个用户 ...

随机推荐

  1. xgboost 最优参数, df某一个字段进行字符串搜索

    0.909323  with:   {'max_depth': 6, 'min_child_weight': 0.8, 'n_estimators': 800} df_huoguo = df[df.c ...

  2. [INS-06006] Passwordless SSH connectivity not set up between the following node(s)

    解决方法1 参考:11.2.0.4 runInstaller: [INS-06006] Passwordless SSH connectivity not set up between the fol ...

  3. 构建RN或Weex项目时,使用Android Studio常遇到的问题

    1 . androidStudio报错No cached version available for offline mode 解决方法 原因是之前为了提高编译速度,在Gradle设置选项中开启了Of ...

  4. html 类似雷达扫描效果 及 闪屏效果

    //雷达扫描效果 1 <em id="Radar" class="RadarFast"></em> css: .RadarFast{ p ...

  5. SpringMVC常见面试题总结

    1.什么是Spring MVC ?简单介绍下你对springMVC的理解? Spring MVC是一个基于MVC架构的用来简化web应用程序开发的应用开发框架,它是Spring的一个模块,无需中间整合 ...

  6. WatchDirService 实时监控

    import config.Config; import java.io.IOException; import java.nio.file.*; import java.util.List; imp ...

  7. Rsync+unison双向文件同步

    1.配置RSYNC服务器的同步源: 基于SSH同步源 rsync -avz /server/rsyncd/*  chen@172.16.23.204:/client/rsyncd 基于RSYNC同步源 ...

  8. Linux服务器---博客wordpress

    Wordpress Wordpress是一个开源的博客平台,是搭建个人博客的首选,用户可以去wordpress中文网站寻找帮助资料 1.下载wordpress软件(https://cn.wordpre ...

  9. PAT (Basic Level) Practice (中文)1002 写出这个数 (20 分)

    题目链接:https://pintia.cn/problem-sets/994805260223102976/problems/994805324509200384 #include <iost ...

  10. JS----对象的合并与克隆

    一. 合并与克隆的差别 1. 克隆是特殊的合并(以空对象作为目标对象,非空对象作为源对象进行合并),克隆要求目标对象与源对象的 constructor相同. 2. 克隆的源对象只有一个,合并的源对象可 ...