1. 引言

前端程序猿主要关注的是页面,你可能根本就用不到.net,java,php等后台语言。

但是你制作出来的网页总要运行、总要测试吧?——那就免不了用到http server。我先前都是用visual studio的,虽然很好用,功能很强大,但是我就开发一个html、javascript、css,干嘛用这种傻大本粗的东西。打开一次特别慢,占内存特别厉害,安装时C盘占去好几个G的空间。

后来闲来无事就换成了nodejs。不用安装任何插件,只需要手动创建三个小文件(总共才2KB),运行即可,速度很快。感觉真的是非常简单、轻量化。特此分享,知道的请略过,不喜勿喷!

2. 四步搭建

第一步,安装nodejs:

不多废话,到www.nodejs.org下载安装即可。

第二步,创建两个js文件

创建两个js文件,分别保存为 server.js  和  mine.js ,代码如下:

 1 var PORT = 8080;       //端口2 var DIR = 'test1';     //用于存放html的目录3 4 var http = require('http');5 var url=require('url');6 var fs=require('fs');7 var mine=require('./mine').types;8 var path=require('path');9
10 var server = http.createServer(function (request, response) {
11     var pathname = url.parse(request.url).pathname;
12     var realPath = path.join(DIR, pathname);
13     //console.log(realPath);
14     var ext = path.extname(realPath);
15     ext = ext ? ext.slice(1) : 'unknown';
16     fs.exists(realPath, function (exists) {
17         if (!exists) {
18             response.writeHead(404, {
19                 'Content-Type': 'text/plain'
20             });
21
22             response.write("This request URL " + pathname + " was not found on this server.");
23             response.end();
24         } else {
25             fs.readFile(realPath, "binary", function (err, file) {
26                 if (err) {
27                     response.writeHead(500, {
28                         'Content-Type': 'text/plain'
29                     });
30                     response.end(err);
31                 } else {
32                     var contentType = mine[ext] || "text/plain";
33                     response.writeHead(200, {
34                         'Content-Type': contentType
35                     });
36                     response.write(file, "binary");
37                     response.end();
38                 }
39             });
40         }
41     });
42 });
43 server.listen(PORT);
44 console.log("Server runing at port: " + PORT + ".");

 1 exports.types = {2   "css": "text/css",3   "gif": "image/gif",4   "html": "text/html",5   "ico": "image/x-icon",6   "jpeg": "image/jpeg",7   "jpg": "image/jpeg",8   "js": "text/javascript",9   "json": "application/json",
10   "pdf": "application/pdf",
11   "png": "image/png",
12   "svg": "image/svg+xml",
13   "swf": "application/x-shockwave-flash",
14   "tiff": "image/tiff",
15   "txt": "text/plain",
16   "wav": "audio/x-wav",
17   "wma": "audio/x-ms-wma",
18   "wmv": "video/x-ms-wmv",
19   "xml": "text/xml"
20 };

我在桌面上新建一个“demo1”的文件夹,把这两个创建好的js文件拷进去。

第三步,创建一个.bat命令文件

还是那个“demo1”文件夹,再在这个文件夹中创建一个“startServer.bat”文件,文件内容其实就一句话:

node server.js

此时 demo1 文件夹中就有了三个文件:

第四步,加入你的html文件

还是那个“demo1”文件夹,我们需要在这个文件中创建一个“test1”文件夹,然后我们加入一个index.html,等会儿做测试用。

重点需要注意:为什么这里会有一个“test1”文件夹呢?因为我们的“server.js”中配置的目录就是“test1”。如果你看着不顺眼,可以改掉,但是要保证两者名称一致。

如果我们在demo1中有好几个测试项目,需要运行哪一个,可以打开“server.js”修改配置即可,非常方便。

3. 一键启动

经过了上面“漫长复杂”的配置过程,到这一步就简单了。

如何“一键”启动? 大家应该都能猜到了——startServer.bat——对,双击运行startServer.bat,控制台即提示你有http server服务了。

端口号默认是“8080”,可以在“server.js”中修改,就在代码第一行。

4. 创建多个http server

咱们上面说了半天,就讲了如何创建第一个http server,其实创建第二个、第三个、第四个……都一样简单。

把 demo1 文件夹中的三个文件,考到你想要创建站点的位置。打开 server.js 修改一下端口号和目录名称,运行startServer.bat就可以了。

想在那里创建http server,就拷贝到哪里,然后运行。不想再用http server了,直接删掉那三个文件就行。

简单易用!

《从设计到模式》深入理解javascript原型和闭包系列》《微软petshop4.0源码解读视频》《json2.js源码解读视频》

文章来源:js便签笔记(14)——用nodejs搭建最简单、轻量化的http server

转载于:https://www.cnblogs.com/qxoffice2008/p/4178129.html

用nodejs搭建最简单、轻量化的http server相关推荐

  1. Pico.css大道至简返璞归真--一个简单轻量化的CSS框架

    Pico.css是什么? Pico.css是一个简单轻量化的CSS UI框架,最大的特点是样式都基于HTML原始的标签名和内置的属性,少用甚至是不用class来定义样式,写出来的代码语义清晰,可维护性 ...

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

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

  3. 自己动手搭建一个简单的静态资源服务器

    文章目录 自己动手搭建一个简单的静态资源服务器 介绍 一.设计到的模块 备注: 二.代码结构 三.具体代码 自己动手搭建一个简单的静态资源服务器 介绍 ​ 通过此文章的学习,可以自己使用NodeJs搭 ...

  4. svn服务器搭建和使用_简单使用nodejs搭建一个静态服务器

    前提:系统安装nodejs 搭建步骤 使用nodejs搭建服务器,简单的来说可以分为三步: require相应的模块 创建服务器 配置端口 启动服务器 必要的nodejs模块 以下模块都是以 var ...

  5. websocket 学习--简单使用,nodejs搭建websocket服务器,到模拟股票,到实现聊天室

    websocket简介: WebSocket协议是 HTML5 开始提供的一种基于TCP的一种新的全双工通讯的网络通讯协议.它允许服务器主动发送信息给客户端. 和http协议的不同?? HTTP 协议 ...

  6. 如何用BIM轻量化引擎搭建BIM协同管理平台

    一个建筑项目从启动到结束,需要设计院.业主.施工方.监理方等多个角色参与其中,进行项目信息与数据的同步与拉通.BIM协同管理平台能实现高效的模型管理.项目进度.信息流转.人员管理,降低项目沟通成本,提 ...

  7. 基于BCoreBIM轻量化引擎搭建BIM云平台

    随着数字化转型在建筑行业的不断推进,BIM云平台在建造项目数据同步.多方工作协同上发挥着重要作用.BIM云平台是否好用,与平台背后的BIM轻量化引擎息息相关. BIM云平台始终围绕两个基础能力进行业务 ...

  8. 刷题H5应用网站源码-无后端无数据库轻量化部署简单

    介绍: 特色内容: 无后端.无数据库轻量化部署简单 使用JSON作为题库存储,层次清晰,结构简单易懂 有配套的word模板和模板到JSON转换工具 四种题模式:顺序题.乱序题.错题模式.背题模式 主要 ...

  9. 【BirdDog】 Full NDI在体育/电竞直播中的降成本、轻量化、多机位现场制作

    2022年IP(NDI)的全球应用规模仍在继续扩大-- 作为视频制作领域内前沿的.富有潮流感的NDI协议,Full NDI采用了浅压缩编码方式,能够实现千兆局域网内的4K/HD高画质.1-3fps低延 ...

最新文章

  1. JavaScript继承的多种方式和优缺点
  2. python开发需要掌握哪些知识-学习Python应该掌握哪些知识点?
  3. innodb和my查询速度_mysql存储引擎MyISAM和InnoDB
  4. linux cmake装在自己目录下,如何在Linux下安装cmake
  5. 小学五年级年级计算机教学计划,小学五年级信息技术教学计划范文
  6. Uva_11427 Expect the Expected
  7. 【DEF CON】数十亿物联网设备受严重随机数生成器缺陷影响
  8. linux 下运行 jar包 java.lang.ClassNotFoundException: 解决办法
  9. 高效的css命名约定
  10. java编程实现食堂饭卡刷卡_食堂饭卡管理系统设计方案报告.docx
  11. iHRM 人力资源管理系统--第1章 SAAS-HRM系统概述与搭建环境
  12. 编程c语言中文图形代码,C语言图形编程代码
  13. 基于JSP和SQL的CD销售管理系统
  14. ARM嵌入式最小系统
  15. Java入门第65课——根据周长计算不同形状图形的面积
  16. 失落世界服务器国庆宝箱位置,失落的斯菲尔 图文攻略 全剧情任务流程全宝箱收集...
  17. 在西安电子科技大学读研是一种什么样的体验
  18. decimal 和 numeric 的区别
  19. springboot之整合Elasticsearch实现搜索
  20. 软件设计师:计算机硬件基础

热门文章

  1. windbg断点学习总结
  2. 过渡期间的测试:外包软件的测试标准(译)
  3. C#6.0语言规范(一) 介绍
  4. Linux7静默安装Oracle11g教程,亲测实用有效!
  5. bzoj3522 Hotel
  6. DecimalFormat格式化输出带小数的数字类型
  7. Net托管世界的应用程序域和线程
  8. 【九度OJ】题目1078-二叉树遍历
  9. 【HDU】5256 系列转换(上涨时间最长的序列修饰)
  10. 如何使用Keil仿真环境查看CPU类型字长?【worldsing笔记】