如何创建一个基于Node的HTTP服务器
首先创建一个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服务器的更多相关文章
- 基于 Node.js 的服务器自动化部署搭建实录
基于 Node.js 的服务器自动化部署搭建实录 在服务器上安装 Node.js 编写拉取仓库.重启服务器脚本 配置 Github 仓库的 Webhook 设置 配置 Node.js 脚本 其他问题 ...
- CXF 入门:创建一个基于WS-Security标准的安全验证(CXF回调函数使用,)
http://jyao.iteye.com/blog/1346547 注意:以下客户端调用代码中获取服务端ws实例,都是通过CXF 入门: 远程接口调用方式实现 直入正题! 以下是服务端配置 ==== ...
- 在C#/.NET应用程序开发中创建一个基于Topshelf的应用程序守护进程(服务)
本文首发于:码友网--一个专注.NET/.NET Core开发的编程爱好者社区. 文章目录 C#/.NET基于Topshelf创建Windows服务的系列文章目录: C#/.NET基于Topshelf ...
- 如何创建一个基于 .NET Core 3 的 WPF 项目
在 Connect(); 2018 大会上,微软发布了 .NET Core 3 Preview,以及基于 .NET Core 3 的 WPF:同时还发布了 Visual Studio 2019 预览版 ...
- 如何创建一个基于 MSBuild Task 的跨平台的 NuGet 工具包
MSBuild 的 Task 为我们扩展项目的编译过程提供了强大的扩展性,它使得我们可以用 C# 语言编写扩展:利用这种扩展性,我们可以为我们的项目定制一部分的编译细节.NuGet 为我们提供了一种自 ...
- 如何创建一个基于命令行工具的跨平台的 NuGet 工具包
命令行可是跨进程通信的一种非常方便的手段呢,只需启动一个进程传入一些参数即可完成一些很复杂的任务.NuGet 为我们提供了一种自动导入 .props 和 .targets 的方法,同时还是一个 .NE ...
- Java中通过方法创建一个http连接并请求(服务器间进行通信)
服务器间进行通信只能通过流(Stream)的方式进行,不能用方法的返回值. 1.Java代码创建一个连接并请求该连接返回的数据 doGet()方法,execute()方法中调用 package dem ...
- javascript创建一个基于数组的栈结构
栈是一种遵从后进先出(LIFO)原则的有序集合.新添加或待删除的元素都保存在栈的同 一端,称作栈顶,另一端就叫栈底.在栈里,新元素都靠近栈顶,旧元素都接近栈底. 栈拥有以下方法: push(eleme ...
- javascript创建一个基于对象的栈结构
上篇博客介绍了基于数组创建一个栈,这是用对象创建一个栈 s1.声明一个Stack类 class Stack { constructor() { this.count = 0; this.items = ...
随机推荐
- Mustache 使用说明
Mustache 使用说明 最近在升级SinGooCMS到MVC架构.管理前端使用了Mustache模板,把使用心得记录一下! 一.官网http://mustache.github.io/https: ...
- swagger简单配置
第一步: 在nuget.org中查找Swashbuckle并下载 在nuget.org中查找Swagger.net.UI,并下载 第二步: 下载完之后,App_Start多了三个文件 Swagger. ...
- linux学习之vi文件编辑命令
如果文件为只读则无法使用普通用户编辑,需要切换到root用户,具体名称可参考: https://www.cnblogs.com/huangwei1992/p/9493443.html vi文件编辑命令 ...
- WORD wFormatTag; /* format type */ //设置波形声音的格式
0x0000 Microsoft Unknown Wave Format 0x0001 Microsoft PCM Format 0x0002 ...
- ClamAV学习【4】——cli_magic_scandesc函数浏览
今晚继续浏览ClamAV代码,挖掘到了cli_magic_scandesc函数,发现前面包装了很多次扫描函数,这里就是最后一层的感觉.一些扫描限制判断加上文件类型判断,采用不同扫描函数处理. (PS: ...
- 动态代理(CGLIB实现)
CGLIB(Code Generation Library)是一个开源项目.可以直接对类进行增强,而不需要像JDK的动态代理,需要增强的类必须实现某接口 在使用Spring框架时,因为Spring框架 ...
- ZJOI2019 游记
Day -2 入住酒店,跟 Sooke 一个房间 酒店还是很好的呢 然后就是颓废 Sooke 和 zxy,ljx,lyt,xx 一起打 lol,我孤独的打着坦克和 MC 然后复习了一下板子 Day - ...
- redis5.0.4-cluster集群搭建及jedis客户端操作
一.去官网下载redis5.0 https://redis.io/download 然后解压安装 $ .tar.gz $ cd redis- $ make 二.准备配置文件 打开redis-5.0.4 ...
- 报错 POST http://192.168.79.165:8015/marketing/manager 400 (BAD REQUEST) 解决办法
我用jQuery ajax post方法 用flask url_for 传值到后端 $.ajax({ url:"{{url_for('marketing.manager')}}", ...
- JAVA数组的遍历和取最值
1.获取数组中的所有元素,会用到数组的遍历 数组的遍历,通常用for循环. public class ArrayDemo { public static void main(String[] args ...