首先创建一个HTTP服务器。

var http = require('http');

function serve(request,response) {
console.log(request.method); //请求的方法
console.log(request.url); //请求里的url,只含有路径名,并不是完整的url
console.log(request.header) //获取请求头 response.statusCode = 200;
//设置响应类型,编码为utf-8。
//服务器返回资源给浏览器时,还应该告诉浏览器这是什么类型的文件,以什么方式解析。不指定的话可能会造成乱码
response.setHeader('Content-Type','text/html;charset=utf-8');
response.setHeader('name','zfpx');
response.write(new Date().toString());
response.end();
} var server = http.createServer(serve);
server.listen(3000);

如果我们希望读取其他文件的内容,则需要先导入fs模块,该模块是读取文件的模块。

var fs = require('fs');
function serve(request,response) {
var url = request.url;//设置响应类型,编码为utf-8。
//服务器返回资源给浏览器时,还应该告诉浏览器这是什么类型的文件,以什么方式解析
response.setHeader('Content-Type','text/html;charset=utf-8');
//如果我们希望返回的是其他文件的内容,则需要先读取其他文件,这时需要fs模块来读取文件
fs.readFile('index.html',function(err,data) {
response.write(data);
response.end();
})
}

但是这样又有一个问题,就是:在对返回的HTML代码开始解析时,解析过程中如果遇到引用的服务器上的资源(额外的CSS,JS代码,图片等资源),需要再次向服务器发送请求,但是不管是发送什么请求,服务器返回的都是index.html文件。这时,我们就需要对不同的请求资源做一个判断,让其返回不同类型的资源。

function serve(request,response) {
var url = request.url;
if (url == '/') {
//设置响应类型,编码为utf-8。
//服务器返回资源给浏览器时,还应该告诉浏览器这是什么类型的文件,以什么方式解析
response.setHeader('Content-Type','text/html;charset=utf-8');
//如果我们希望返回的是其他文件的内容,则需要先读取其他文件,这时需要fs模块来读取文件
fs.readFile('index.html',function(err,data) {
response.write(data);
response.end();
})
}else if (url == '/style.css') {
response.setHeader('Content-Type','text/css;charset=utf-8');
//如果我们希望返回的是其他文件的内容,则需要先读取其他文件,这时需要fs模块来读取文件
fs.readFile('style.css',function(err,data) {
response.write(data);
response.end();
})
}

一个页面里,我们可能会请求非常多的静态资源,如果每次都加一个else if 显然让页面更复杂,且不利于维护。所以我们希望将所有的静态资源请求都封装在一个函数里。

function parseMime(pathname) {
var reg = /\.(HTML|JS|CSS|JSON|TXT|ICO|JPG)/i;
if (reg.test(pathname)) {
//获取请求文件的后缀名
var suffix = reg.exec(pathname)[1].toUpperCase();
//根据请求文件的后缀名获取到当前文件的MIME类型
var suffixMIME = "text/plain";
switch(suffix) {
case "HTML":
suffixMIME = "text/html";
break;
case "CSS":
suffixMIME = "text/css";
break;
case "JS":
suffixMIME = "text/javascript";
break;
case "JSON":
suffixMIME = "application/json";
break;
case "ICO":
suffixMIME = "application/octet-stream";
break;
case "JPG":
suffixMIME = "image/jpg";
break; }
}
return suffixMIME;
}

实际上,Node中还提供了一个第三方的模块能够自动帮我们判断文件的MIME类型,我们这里还需要用到一个第三方的模块"mine"。

var mime = require('mime');

function serve(request,response) {
var url = request.url;
if (url == '/') {
//设置响应类型,编码为utf-8。
//服务器返回资源给浏览器时,还应该告诉浏览器这是什么类型的文件,以什么方式解析
response.setHeader('Content-Type','text/html;charset=utf-8');
//如果我们希望返回的是其他文件的内容,则需要先读取其他文件,这时需要fs模块来读取文件
fs.readFile('index.html',function(err,data) {
response.write(data);
response.end();
})
}else{
static(url,response)
}
} function static(url,response) {
response.setHeader('Content-Type',mime.lookup(url) + ';charset=utf-8');
//如果我们希望返回的是其他文件的内容,则需要先读取其他文件,这时需要fs模块来读取文件
fs.readFile(url.slice(1),function(err,data) {
response.write(data);
response.end();
}) }

现在我们的url都是类似http://localhost:3000/index.html这样的,就是客户端只是单纯的获取数据,并不涉及向服务器端发送数据。

前面我们说过,request.url获取的是'3000:'之后的内容,那么当我们需要向服务器传一些内容的时候,比如说http://localhost:3000/index.html/?name="xiaoyu"。这时request.url获取的就是/index.html/?name="xiaoyu"。

这样的url显然不能再作为我们判断路径的依据,所以我们得进一步处理这个url。其实node提供了一个更加强大的url解析库给我们,这个库就是”url“。这个库能够解析整个完整的url路径。

传送地址:url模块学习小结

如何创建一个基于Node的HTTP服务器的更多相关文章

  1. 基于 Node.js 的服务器自动化部署搭建实录

    基于 Node.js 的服务器自动化部署搭建实录 在服务器上安装 Node.js 编写拉取仓库.重启服务器脚本 配置 Github 仓库的 Webhook 设置 配置 Node.js 脚本 其他问题 ...

  2. CXF 入门:创建一个基于WS-Security标准的安全验证(CXF回调函数使用,)

    http://jyao.iteye.com/blog/1346547 注意:以下客户端调用代码中获取服务端ws实例,都是通过CXF 入门: 远程接口调用方式实现 直入正题! 以下是服务端配置 ==== ...

  3. 在C#/.NET应用程序开发中创建一个基于Topshelf的应用程序守护进程(服务)

    本文首发于:码友网--一个专注.NET/.NET Core开发的编程爱好者社区. 文章目录 C#/.NET基于Topshelf创建Windows服务的系列文章目录: C#/.NET基于Topshelf ...

  4. 如何创建一个基于 .NET Core 3 的 WPF 项目

    在 Connect(); 2018 大会上,微软发布了 .NET Core 3 Preview,以及基于 .NET Core 3 的 WPF:同时还发布了 Visual Studio 2019 预览版 ...

  5. 如何创建一个基于 MSBuild Task 的跨平台的 NuGet 工具包

    MSBuild 的 Task 为我们扩展项目的编译过程提供了强大的扩展性,它使得我们可以用 C# 语言编写扩展:利用这种扩展性,我们可以为我们的项目定制一部分的编译细节.NuGet 为我们提供了一种自 ...

  6. 如何创建一个基于命令行工具的跨平台的 NuGet 工具包

    命令行可是跨进程通信的一种非常方便的手段呢,只需启动一个进程传入一些参数即可完成一些很复杂的任务.NuGet 为我们提供了一种自动导入 .props 和 .targets 的方法,同时还是一个 .NE ...

  7. Java中通过方法创建一个http连接并请求(服务器间进行通信)

    服务器间进行通信只能通过流(Stream)的方式进行,不能用方法的返回值. 1.Java代码创建一个连接并请求该连接返回的数据 doGet()方法,execute()方法中调用 package dem ...

  8. javascript创建一个基于数组的栈结构

    栈是一种遵从后进先出(LIFO)原则的有序集合.新添加或待删除的元素都保存在栈的同 一端,称作栈顶,另一端就叫栈底.在栈里,新元素都靠近栈顶,旧元素都接近栈底. 栈拥有以下方法: push(eleme ...

  9. javascript创建一个基于对象的栈结构

    上篇博客介绍了基于数组创建一个栈,这是用对象创建一个栈 s1.声明一个Stack类 class Stack { constructor() { this.count = 0; this.items = ...

随机推荐

  1. Selenium窗口切换-----Selenium快速入门(六)

    有时候,我们打开多个窗口,进行多窗口操作,那么窗口间该如何切换呢? 切换的方法有两个,一个是通过窗口标题来验证,另一个是通过窗口特定的内容来验证,这两个方法都要求得到的标题或内容是唯一的. 用到的相关 ...

  2. API Test Postman接口测试之高级篇1

    API Test  Postman接口测试之高级篇1 一.postman中的请求参数简介: 1.请求参数简介: 点击params下面会出现key,value等信息,这里填写的会自动追加在url地址后面 ...

  3. kubectl get componentstatus ERROR:HTTP probe failed with statuscode: 503

    通过kubectl命令可以查看k8s各组件的状态: [root@wecloud-test-k8s-1 ~]# kubectl get cs NAME STATUS MESSAGE ERROR cont ...

  4. djang系列5.5-- 图书管理系统实例

    一.表格设计 E-R图 分析图 models.py from django.db import models # Create your models here. class Author(model ...

  5. 配置AndroidStdio的开发环境

    http://blog.csdn.net/siwuxie095/article/details/53431818

  6. iOS开发网络篇—GET请求和POST请求的说明与比较

    1.GET请求和POST请求简单说明 1.1 创建GET请求 // 1.设置请求路径 NSString *urlStr = [NSString stringWithFormat:@"http ...

  7. php函数源代码 C编写 【持续更新】

    由于经常被抓取文章内容,在此附上博客文章网址:,偶尔会更新某些出错的数据或文字,建议到我博客地址 :  --> 点击这里 strlen() 获取字符串长度,成功则返回字符串 string 的长度 ...

  8. ObjectARX动态添加AutoCAD传统下拉菜单入门篇(一)

    ObjectARX动态添加传统下拉菜单入门篇 图文by edata  , 转载注明出处 http://www.cnblogs.com/edata AutoCAD 添加传统下拉菜单有很多种方式,比较典型 ...

  9. 【flask】 学习flask macro 模板

    首先 我是看着这个链接学习的 jinja2 macro官方文档 Flask开发中Macros的实践经验 Flask的Jinja2模板引擎 — 块与宏(6th) 在宏中 还可以赋值...用set标签.. ...

  10. python获取aliyun ECS实例

    #!/usr/bin/env python #-*- coding:utf-8 -*- # Description : get ecs from aliyun # Author : quke # Da ...