Nodejs学习第二天

今天开始学习Nodejs官网提供api(一般称这为模块)练习,类似java JDK, 根据第一天代码:

 //导入 http模块
 var http = require('http');
 //创建一个httpServer 并监听8081端口
 http.createServer(function (req, res) {
//响应客户端请求,并输出信息 --> Hello, World.
  res.writeHead(200, {'Content-Type': 'text/plain'});
  res.write('Hello, World.');
  res.end(); //结束本次请求
 }).listen(8081);

以上是一个很简单的web程序,提供了从服务器端到应用端的全部流程,这里的业务逻辑非常简单,只是向页面输出字符串 Hello, World. .

接下来,根据我学习后的理解全手动编写了如下代码(#-_-),稍微能处理来自不同的请求,类似java # DispatcherServlet :

首先,先定义程序的入口,虽然js没有main函数, 新建一个index.js, 先不计划编码任何代码。
然后,新建server.js,用来存放第一天学习的部分内容,就像文件名一样,是一个类似server的功能,代码如下:

 //导入http 和 url模块 类似java的 Map\\\\List等工具类
var http = require('http'),
    url = require('url') ;
 function start() {
  //请求处理函数,就是第一天学习的箭头函数,这里不再是一个匿名函数
  function onRequest(req,res) {
   //这里通过url模块提供函数 parse获得请求方法,详细可以参考node官方网站document说明
   var pathName = url.parse(req.url).pathname ;
   console.log('request path ',pathName) ;
   //响应状态码 和格式
   res.writeHead(200,{'Content-Type':'text/plain'}) ;

   res.write('Hello,World.') ;
   res.end() ;
  }

  http.createServer(onRequest).listen(8081) ;
  console.log('server has started.') ;
 }

 //将函数start函数导出为一个模块
 //export
 exports.start = start ;

然后回到index.js中 编写如下代码:

//导入刚才我们编写的server模块
 var server = require('./server') ;

//调用模块提供server功能
 server.start() ;

然后可以运行如下命令:

node index.js

访问http://localhost:8081 ,可以看到输出。

上面代码将业务逻辑放到了 server中,在实际工作中,这明显是非常不合理的,因为业务逻辑变更比女人翻脸还快,放到server中后果可想而知。这里需要调整,记得在刚开始学习java #servlet 的时候,我们最开始是使用get方式将方法传递到服务器端,然后通过永远也写不完的if....else if.... else if.... 来进行不同功能的分发,这里如果提供一个类似路由表的东西就可以达到类似的目的,由于javaScript对象是key-value的形式出现,这给这一功能提供了方便,例如:

var handle = {} ;
handle['/'] = root ; //代表访问项目首页
handle['/start'] = start ; //代表访问项目首页
handle['/upload'] = upload ; //代表上传文件请求

这样,不同的功能类似一张路由表被关联起来了,例如:

//dispatcher.js
 function start() {
  console.log('call /start') ;

  return 'call /start' ;
 }

 function upload() {
  console.log('call /upload') ;
  return 'call /upload' ;
 }

 function root() {
  console.log('call /') ;
  return 'call /' ;
 }

 exports.start = start ;
 exports.upload = upload ;
 exports.root = root ;

以上代码表示不同需求的功能函数。然后再提供一个路由转发功能的模块,例如:

//router.js
 function route(path,handle) {
  console.log('route path ',path) ;

  var fun = handle[path] ;
  if(typeof fun === "function") {
   return fun.call(null,arguments) ;
  }else {
   console.log('unknown path.') ;
   return 'unknown path.' ;
  }
 }

 exports.route = route ;

然后我们需要对index.jsserver.js 中的代码进行适当的修改,如下:

server.js

//server.js
 //导入http 和 url模块 类似java的 Map\\\\List等工具类
var http = require('http'),
    url = require('url') ;
 //服务启动需要传递两个参数,handle为转发提供映射表,route执行转发
function start(handle,route) {
  //请求处理函数,就是第一天学习的箭头函数,这里不再是一个匿名函数
  function onRequest(req,res) {
   //这里通过url模块提供函数 parse获得请求路径,详细可以参考node官方网站document说明
   var pathName = url.parse(req.url).pathname ;
   console.log('request path ',pathName) ;
   //响应状态码 和格式
   res.writeHead(200,{'Content-Type':'text/plain'}) ;
  //使用route 模块进行转发请求,这里为了能看到明显的效果,将不同功能信息输出到页面
   //dispatcher
   var content = route(pathName,handle) ;
   console.log('return content',content) ;

   res.write(content) ;
   //res.write('Hello,World.') ;
   res.end() ;
  }

  http.createServer(onRequest).listen(8081) ;
  console.log('server has started.') ;
 }

 //将函数start函数导出为一个模块
 //export
 exports.start = start ;

index.js

//index.js

 var server = require('./server'),
     router = require('./router'),
     dispatcher = require('./dispatcher');

 var handle = {} ;
 handle['/'] = dispatcher.root ;
 handle['/start'] = dispatcher.start ;
 handle['/upload'] = dispatcher.upload ;
 server.start(handle,router.route) ;

运行 node index.js ,并访问映射路径可以看到不同的输出信息, 例如: http://localhost:8081/upload // call /upload

至此,第二天nodejs的学习到这里就结束啦,#-_- 晚安! 以上内容如有发现错误一定请各位朋友指出,非常感谢!

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,723评论 6 498
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,003评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,512评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,825评论 1 290
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,874评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,841评论 1 295
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,812评论 3 416
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,582评论 0 271
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,033评论 1 308
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,309评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,450评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,158评论 5 341
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,789评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,409评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,609评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,440评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,357评论 2 352

推荐阅读更多精彩内容

  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 134,649评论 18 139
  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 172,039评论 25 707
  • Express 简介 Express 是一个简洁而灵活的 node.js Web应用框架, 提供了一系列强大特性帮...
    保川阅读 2,013评论 0 24
  • 九重天,莲花池。 她本是下界雾灵山上一株修炼了五百年的桃花妖,因她结出的桃子酸甜无比,深得王母喜爱,便被玉帝从...
    我叫王莹莹阅读 905评论 2 2
  • 靠璞刺青阅读 274评论 3 3