前言:

  如果我们使用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. Java Thread 的 sleep() 和 wait() 的区别

    Java Thread 的使用 Java Thread 的 run() 与 start() 的区别 Java Thread 的 sleep() 和 wait() 的区别       1. sleep ...

  2. 05.GitHub实战系列~5.发布版本之分支操作+Tag讲解 2015-12-14

    GitHub实战系列汇总:http://www.cnblogs.com/dunitian/p/5038719.html ———————————————————————————————————————— ...

  3. ASP.NET MVC5+EF6+EasyUI 后台管理系统(42)-工作流设计-表建立

    系列目录 工作流在实际应用中还是比较广泛,网络中存在很多工作流的图形化插件,可以做到拉拽的工作流设计,非常简便,再配合第三方编辑器,可以直接生成表单,我没有刻意的浏览很多工作流的实际设计,我认为工作流 ...

  4. KindEditor 给KindEditor赋值

    在项目的过程中,使用了KindEditor编辑器,然后在赋值的时候,我的编辑器ID是content,然后我想通过$("#content").html()来赋值,发现赋值失败,后来百 ...

  5. call,apply,bind的用法

    关于call,apply,bind这三个函数的用法,是学习javascript这门语言无法越过的知识点.下边我就来好好总结一下它们三者各自的用法,及常见的应用场景. 首先看call这个函数,可以理解成 ...

  6. Laravel学习--关于Relation的坑

    前段时间比较忙,就没有坚持写博客,但发现这周末再想捡起来,好难,一直到了今天晚上,才决定坐下来写一篇,哈哈哈-- 最近在用 Laravel 5.2,踩了几个关于 Relation 的坑,在这里用博客记 ...

  7. 1、.NET平台概述

        本学习主要参考Andrew Troelsen的C#与.NET4高级程序设计,这小节主要述说以下几个东西:     宏观上讨论一下.net相关的主题:程序集.CIL(Common Interme ...

  8. position:sticky的兼容性尝试

    开篇 笔者刚刚结束淘宝的工作,现在加入了一家有青春活力的垂直电商公司,正对着阿里巴巴的西溪园区,最近一直在熟悉新的工作环境和规范,因此博客有好些时间没有更新了,在此抱歉! 在忙碌完公司的发布系统之后, ...

  9. 深入理解Spring--动手实现一个简单的SpringIOC容器

    接触Spring快半年了,前段时间刚用Spring4+S2H4做完了自己的毕设,但是很明显感觉对Spring尤其是IOC容器的实现原理理解的不到位,说白了,就是仅仅停留在会用的阶段,有一颗想读源码的心 ...

  10. [占位-未完成]scikit-learn一般实例之十:核岭回归和SVR的比较

    [占位-未完成]scikit-learn一般实例之十:核岭回归和SVR的比较