注册入学 登录
柠檬大学-伴我成长 返回首页

a1023456的个人空间 https://www.08nm.com/?2 [收藏] [复制] [分享] [RSS]

日志

[转载]Nodejs实现路由选择

已有 1383 次阅读2013-5-15 17:06 | 上下文

初学Node,发现了与自己之前的观点完全不同的场面——你眼中的JavaScript,是干什么用的呢?特效?or 只是与客户端的交互?可以说,JavaScript最早是运行在浏览器中的,然而你要这样想,浏览器只是你提供了一个上下文(context),它定义了使用JavaScript可以做什么,这里可以想成类似的一个企业,企业定义了你可以在这里做什么,但是并没有说太多关于JavaScript语言本身可以做什么。事实上,作为一门完整的语言,JavaScript可以使用在不同的上下文中,体现出不同的能力。这里所讲到的Nodejs其实说白了就是提供的一个上下文,一个运行环境,它允许在后端(脱离浏览器环境)来运行JavaScript代码。

路由选择的核心是路由,顾名思义,路由指的就是我们要针对不同的URL有不同的处理方式,例如处理/start的业务逻辑和处理/upload模块的业务;逻辑就是不一致的。在现实的实现下,路由过程会在路由模块中“结束”,并且路由模块并不是真正者针对请求“采取行动”的模块,否则当我们的应用程序变得更为复杂的时候就将无法得到很好的扩展。

这里我们首先创建一个叫做requestHandlers的模块,对于每一个请求处理程序都添加一个占位函数:

 
  1. function start(){   
  2.     console.log("Request handler ’start’ was called.");   
  3.        
  4.     function sleep(milliSeconds){   
  5.         var startTime=new Date().getTime();   
  6.         while(new Date().getTime()<startTime+milliSeconds);   
  7.     }   
  8.     sleep(10000);   
  9.     return "Hello Start";   
  10. }   
  11. function upload(){   
  12.     console.log("Request handler ’upload’ was called.");   
  13.     return "Hello Upload";   
  14. }   
  15.   
  16. exports.start=start;   
  17. exports.upload=upload;  

 

 这样我们就可以将请求处理程序和路由模块连接起来,让路由“有路可循”。之后我们确定将一系列请求处理程序通过一个对象来传递,并且需要使用松耦合的方式将这个对象注入到router()函数中,主文件index.js:
  1. var server=require("./server");   
  2. var router=require("./router");   
  3. var requestHandlers=require("./requestHandlers");   
  4.   
  5. var handle={};   
  6. handle["/"]=requestHandlers.start;   
  7. handle["/start"]=requestHandlers.start;   
  8. handle["/upload"]=requestHandlers.upload;   
  9.   
  10. server.start(router.route,handle);  

 如上所示,将不同的URL映射到相同的请求处理程序上是容易的:只要在对象中添加一个键为“/”的属性,对应requestHandlers.start即可。这样我们就可以简洁地配置/start和/的请求都交给start这一处理程序来处理。在完成看对象的定义后,我们将它作为额外的参数传递给服务器,见server.js:

  1. var http=require("http");   
  2. var url=require("url");   
  3.   
  4. function start(route,handle){   
  5.     function onRequest(request,response){   
  6.         var pathname=url.parse(request.url).pathname;   
  7.         console.log("Request for "+pathname+" received.");   
  8.            
  9.         route(handle,pathname);   
  10.            
  11.         response.writeHead(200,{"Content-Type":"text/plain"});   
  12.         var content=route(handle,pathname);   
  13.         response.write(content);   
  14.         response.end();   
  15.     }   
  16.     http.createServer(onRequest).listen(8888);   
  17.     console.log("Server has started.");   
  18. }    
  19. exports.start=start; 

 这样就在start()函数中添加了handle参数,并且把handle对象作为第一个参数传递给了route()回调函数,下面定义route.js:

 
  1. function route(handle,pathname){   
  2.     console.log("About to route a request for "+ pathname);   
  3.     if(typeof handle[pathname]===’function‘){   
  4.         return handle[pathname]();   
  5.     }else{   
  6.         console.log("No request handler found for "+pathname);   
  7.         return "404 Not Found";   
  8.     }   
  9. }   
  10. exports.route=route;  

 

 通过以上代码,我们首先检查给定的路径对应的请求处理程序是否存在,如果存在则直接调用相应的函数。我们可以用从关联数组中获取元素一样的方式从传递的对象中获取请求处理函数,即handle[pathname]();这样的表达式,给人一种感觉就像是在说“嗨,请你来帮我处理这个路径。”程序运行效果如下图:



来源:http://www.jackpakistan.com/2012/09/nodejs%E5%AE%9E%E7%8E%B0%E8%B7%AF%E7%94%B1%E9%80%89%E6%8B%A9


路过

鸡蛋

鲜花

握手

雷人

评论 (0 个评论)

facelist

您需要登录后才可以评论 登录 | 注册入学

联系我们|Archiver|小黑屋|手机版|滚动|柠檬大学 ( 京ICP备13050917号-2 )

GMT+8, 2024-5-2 18:15 , Processed in 0.091807 second(s), 18 queries .

Powered by Discuz! X3.5 Licensed

© 2001-2023 Discuz! Team.

返回顶部