前言:

  如果我们使用PHP来编写后端的代码时,需要Apache 或者 Nginx 的HTTP 服务器,并配上 mod_php5 模块和php-cgi。

  从这个角度看,整个"接收 HTTP 请求并提供 Web 页面"的需求根本不需 要 PHP 来处理。

  不过对 Node.js 来说,概念完全不一样了。使用 Node.js 时,我们不仅仅 在实现一个应用,同时还实现了整个 HTTP 服务器。

  事实上,我们的 Web 应用以及对应的 Web 服务器基本上是一样的。


创建一个简单的HTTP服务器:

  这里我们使用创建文件,然后执行的方式,来创建此实例。

  在E:\NodejsDemo文件夹下,创建“server.js”文件,代码如下:

 var http = require("http");

 http.createServer(function(request,response){
     response.writeHead(200, {"Content-Type" : "text/plain"});
     response.end("Hello World!\n");
 }).listen(88);

 console.log("Server running at http://127.0.0.1:88/")

  上述代码中,我们先引入了http模块,并存入本地的http对象中。

  然后使用http对象创建一个服务,设置文档响应类型等,最后结束并返回响应一串字符串。

  启动监听在88端口。

  以上代码,我们已经完成了一个简单Node.js的HTTP服务器的创建。

  下面我们在DOS下使用node命令来运行它:

  

  此时,防火墙可能会提示,点击允许访问即可:

  

  然后、我们打开浏览器,访问地址:http://127.0.0.1:88,效果如下:

  

  看到这个界面了,是不是很鸡冻,哈哈。


强化案例:

  不知道大家是否了解类似于JSP、ASP.NET的运行机制。

  例如JSP,解析的时候,最后生成的是HTML源码文件,将源JSP文件中的代码一行行拼接输出。

  按照这个原理,我们能不能也实现一个HTML的服务器呢?

  主程序“main.js”的代码如下:

 var http = require("http");

 var html = "";
 html += "<!DOCTYPE html>";
 html += "<html>";
 html += "   <head>";
 html += "       <meta charset='utf-8' />";
 html += "       <title>孤影'Blog</title>";
 html += "       <style>body{background:black; color:#0F6; text-align:center; text-shadow:0px 0px 10px #0F6;}</style>";
 html += "   </head>";
 html += "   <body>";
 html += "       <h1>孤影'Blog</1>";
 html += "       <h2>Welcome to my blog!</h2>";
 html += "   </body>";
 html += "</html>";

 http.createServer(function (request, response) {
     response.writeHead(200, { "Content-Type": "text/html" });
     response.end(html);
 }).listen(88);

  OK、打开DOS、运行“node main.js”,效果如下:

  有没有脑洞大开?!呵呵。下山自行修炼去吧。哈哈。。


简单分析Node.js的HTTP服务器:

  这里,我奉承简单入门为主,所以就不做过多的介绍了,大家理解就好。

  W3C官方的解释如下:

  • 第一行请求(require)Node.js 自带的 http 模块,并且把它赋值给 http 变量。
  • 接下来我们调用 http 模块提供的函数: createServer 。这个函数会返回 一个对象,这个对象有一个叫做 listen 的方法,这个方法有一个数值参数, 指定这个 HTTP 服务器监听的端口号。

  个人介绍:

  1. require表示引入一个模块,在这里,我们引入的是系统的http模块,从而创建了一个http模块服务。
  2. 然后,我们把它赋值保存到了一个http对象中。
  3. 下面,我们使用该对象的createServer方法,执行了一个function函数。
  4. 该函数传入一个request和response的请求及响应对象,设置响应状态码为200,响应类型为text文本,响应内容为“Hello World!”。
  5. 最后,调用其“listen”方法,启动监听,监听端口为88。
  6. 命令结束的时候,我们输出了一段日志:“Server running at http://127.0.0.1:88”。

小结:

  我也是刚学,所以深刻体会,这个东西慢慢的理解就好,别太死扣语法了。循序渐进的而已。

  希望大家赶紧上手吧,呵呵。

Node.js 教程 03 - 创建HTTP服务器的更多相关文章

  1. Node.js 教程 01 - 简介、安装及配置

    系列目录: Node.js 教程 01 - 简介.安装及配置 Node.js 教程 02 - 经典的Hello World Node.js 教程 03 - 创建HTTP服务器 Node.js 教程 0 ...

  2. Node.js 教程 04 - 模块系统

    前言: Node.js的模块系统类似于C/C++的文件引用,可以声明对象,也可以定义类 创建对象. 大家这么理解,就简单了. 定义: 为了让Node.js的文件可以相互调用,Node.js提供了一个简 ...

  3. [转载]Node入门 » 一本全面的Node.js教程

    http://www.nodebeginner.org/index-zh-cn.html 作者: Manuel Kiessling 翻译: goddyzhao & GrayZhang & ...

  4. 【转载】Node.js 教程(菜鸟教程系列)

    很好的一篇教程:Node.js 教程 简单做下笔记 概述 简单的说 Node.js 就是运行在服务端的 JavaScript. Node.js 是一个基于Chrome JavaScript 运行时建立 ...

  5. 10+ 最佳的 Node.js 教程和实例

    如果你正在找Node.js的学习资料及指南,那么请继续(阅读),我们的教程将会覆盖即时聊天应用.API服务编写.投票问卷应用.人物投票APP.社交授权. Node.js on Raspberry Pi ...

  6. Fenix – 基于 Node.js 的桌面静态 Web 服务器

    Fenix 是一个提供给开发人员使用的简单的桌面静态 Web 服务器,基于 Node.js 开发.您可以同时在上面运行任意数量的项目,特别适合前端开发人员使用. 您可以通过免费的 Node.js 控制 ...

  7. 实用的 Node.js 教程,工具和资源

    这里分享一批实用的实用的 Node.js 教程,工具和资源. Node.js是一个建立在Chrome之上的JavaScript运行时平台,可方便地构建快速,可扩展的网络应用程序.Node.js使用事件 ...

  8. node.js 学习03

    node.js学习03 解决浏览器接收服务端信息之后乱码的问题: 服务器通过设置http响应报文头,告诉浏览器使用相应的编码 来解析网页. res.setHeader('Content','text/ ...

  9. Node.js教程系列~目录

    Node.js这个东西在近几年火起来了,而且会一直火下去,无论在infoq还是在cnblogs,csdn上,都可以到处看到它的样子,它主推的应该就是异步式I/O 吧,是的,设计的很完美,很吸引人,虽然 ...

随机推荐

  1. Azure 上通过 SendGrid 发送邮件

    SendGrid 是什么? SendGrid 是架构在云端的电子邮件服务,它能提供基于事务的可靠的电子邮件传递. 并且具有可扩充性和实时分析的能力.常见的用例有: 自动回复用户的邮件 定期发送信息给用 ...

  2. Entity Framework 6 Recipes 2nd Edition(10-9)译 -> 在多对多关系中为插入和删除使用存储过程

    10-9. 在多对多关系中为插入和删除使用存储过程 问题 想要在一个无载荷的多对多关系中使用存储过程(存储过程只影响关系的连接表) 解决方案 假设有一个多对多关系的作者( Author)表和书籍( B ...

  3. SSH框架整合(代码加文字解释)

    一.创建数据库并设置编码. A) create database oa default character set utf8. 二.MyEclipse工程 A) 在Myeclipse里创建web工程, ...

  4. Atitit 图像处理 调用opencv 通过java  api   attilax总结

    Atitit 图像处理 调用opencv 通过java  api   attilax总结 1.1. Opencv java api的支持 opencv2.4.2 就有了对java api的支持1 1. ...

  5. JS 对象封装的常用方式

    JS是一门面向对象语言,其对象是用prototype属性来模拟的,下面,来看看如何封装JS对象. 常规封装 function Person (name,age,sex){ this.name = na ...

  6. gradlew wrapper使用下载到本地的gradle.zip文件装配--转

    原文地址:http://www.myexception.cn/mobile/1860089.html gradlew wrapper使用下载到本地的gradle.zip文件安装.使用gradlew来b ...

  7. SQL Tuning 基础概述01 - Autotrace的设定

    1.autotrace的设定 SQL> set autotrace Usage: SET AUTOT[RACE] {OFF | ON | TRACE[ONLY]} [EXP[LAIN]] [ST ...

  8. 浅谈css的伪元素::after和::before

    css中的::after和::before已经被大量地使用在我们日常开发中了,使用他们可以使我们的文档结构更加简洁.但是很多人对::after和::before仍不是特别了解,究竟他们是做什么的?如何 ...

  9. Apworks框架实战(六):使用基于Entity Framework的仓储基础结构

    在前面的章节中,我们已经设计了一个简单的领域模型,接下来我们希望能够实现领域模型的持久化及查询.在Apworks中,实现了面向Entity Framework.NHibernate以及MongoDB的 ...

  10. 基于 HTML5 的 WebGL 技术构建 3D 场景(一)

    今天和大家分享的是 3D 系列之 3D 预定义模型. HT for Web 提供了多种基础类型供用户建模使用,不同于传统的 3D 建模方式,HT 的建模核心都是基于 API 的接口方式,通过 HT 预 ...