nodejs中实现路由功能


Posted in NodeJs onDecember 29, 2014

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

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

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

function start(){   

    console.log("Request handler 'start' was called.");   

       

    function sleep(milliSeconds){   

        var startTime=new Date().getTime();   

        while(new Date().getTime()<startTime+milliSeconds);   

    }   

    sleep(10000);   

    return "Hello Start";   

}   

function upload(){   

    console.log("Request handler 'upload' was called.");   

    return "Hello Upload";   

}   

  

exports.start=start;   

exports.upload=upload;

这样我们就可以将请求处理程序和路由模块连接起来,让路由“有路可循”。之后我们确定将一系列请求处理程序通过一个对象来传递,并且需要使用松耦合的方式将这个对象注入到router()函数中,主文件index.js:

var server=require("./server");   

var router=require("./router");   

var requestHandlers=require("./requestHandlers");   

  

var handle={};   

handle["/"]=requestHandlers.start;   

handle["/start"]=requestHandlers.start;   

handle["/upload"]=requestHandlers.upload;   

  

server.start(router.route,handle);

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

var http=require("http");   

var url=require("url");   

  

function start(route,handle){   

    function onRequest(request,response){   

        var pathname=url.parse(request.url).pathname;   

        console.log("Request for "+pathname+" received.");   

           

        route(handle,pathname);   

           

        response.writeHead(200,{"Content-Type":"text/plain"});   

        var content=route(handle,pathname);   

        response.write(content);   

        response.end();   

    }   

    http.createServer(onRequest).listen(8888);   

    console.log("Server has started.");   

}    

exports.start=start;

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

function route(handle,pathname){   

    console.log("About to route a request for "+ pathname);   

    if(typeof handle[pathname]==='function‘){   

        return handle[pathname]();   

    }else{   

        console.log("No request handler found for "+pathname);   

        return "404 Not Found";   

    }   

}   

exports.route=route;

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

 

nodejs中实现路由功能

NodeJs 相关文章推荐
使用Nodejs开发微信公众号后台服务实例
Sep 03 NodeJs
浅析nodejs实现Websocket的数据接收与发送
Nov 19 NodeJs
Nodejs从有门道无门菜鸟起飞必看教程
Jul 20 NodeJs
详解如何在NodeJS项目中优雅的使用ES6
Apr 22 NodeJs
Nodejs读取文件时相对路径的正确写法(使用fs模块)
Apr 27 NodeJs
Nodejs中Express 常用中间件 body-parser 实现解析
May 22 NodeJs
NodeJS简单实现WebSocket功能示例
Feb 10 NodeJs
Mac下通过brew安装指定版本的nodejs教程
May 17 NodeJs
Nodejs把接收图片base64格式保存为文件存储到服务器上
Sep 26 NodeJs
nodejs实现范围请求的实现代码
Oct 12 NodeJs
nodejs微信开发之授权登录+获取用户信息
Mar 17 NodeJs
nodejs处理tcp连接的核心流程
Feb 26 NodeJs
NodeJS制作爬虫全过程(续)
Dec 22 #NodeJs
NodeJS制作爬虫全过程
Dec 22 #NodeJs
nodejs中操作mysql数据库示例
Dec 20 #NodeJs
轻松创建nodejs服务器(10):处理上传图片
Dec 18 #NodeJs
轻松创建nodejs服务器(10):处理POST请求
Dec 18 #NodeJs
轻松创建nodejs服务器(7):阻塞操作的实现
Dec 18 #NodeJs
轻松创建nodejs服务器(8):非阻塞是如何实现的
Dec 18 #NodeJs
You might like
当年上海收录机产品生产,进口和价格情况
2021/03/04 无线电
解析Extjs与php数据交互(增删查改)
2013/06/25 PHP
浅析Dos下运行php.exe,出现没有找到php_mbstring.dll 错误的解决方法
2013/06/29 PHP
thinkPHP引入类的方法详解
2016/12/08 PHP
JavaScript入门教程(5) js Screen屏幕对象
2009/01/31 Javascript
js 分栏效果实现代码
2009/08/29 Javascript
js修改table中Td的值(定义td的单击事件)
2013/01/10 Javascript
jQuery超精致图片轮播幻灯片特效代码分享
2015/09/10 Javascript
jQuery拖拽排序插件制作拖拽排序效果(附源码下载)
2016/02/23 Javascript
javascript创建cookie、读取cookie
2016/03/31 Javascript
Bootstrap每天必学之模态框(Modal)插件
2016/04/26 Javascript
javascript基础语法——全面理解变量和标识符
2016/06/02 Javascript
H5移动端图片压缩上传开发流程
2016/11/09 Javascript
jQuery实现键盘回车搜索功能
2017/07/25 jQuery
解决npm安装Electron缓慢网络超时导致失败的问题
2018/02/06 Javascript
elementui更改el-dialog关闭按钮的图标d的示例代码
2020/08/04 Javascript
[05:13]TI4 中国战队 机场出征!!
2014/07/07 DOTA
Python引用(import)文件夹下的py文件的方法
2014/08/26 Python
Python闭包实现计数器的方法
2015/05/05 Python
Python断言assert的用法代码解析
2018/02/03 Python
ubuntu安装sublime3并配置python3环境的方法
2018/03/15 Python
Python简单实现网页内容抓取功能示例
2018/06/07 Python
对python requests发送json格式数据的实例详解
2018/12/19 Python
python如何实现单链表的反转
2020/02/10 Python
浅谈Pytorch中的自动求导函数backward()所需参数的含义
2020/02/29 Python
Python更换pip源方法过程解析
2020/05/19 Python
Python selenium使用autoIT上传附件过程详解
2020/05/26 Python
HTML5中原生的右键菜单创建方法
2016/06/28 HTML / CSS
国际书籍零售商:Wordery
2017/11/01 全球购物
Stio官网:男女、儿童户外服装
2019/12/13 全球购物
JAVA高级程序员面试题
2013/09/06 面试题
销售经理工作职责范文
2013/12/03 职场文书
公司财务流程之主管工作流程
2014/03/03 职场文书
教师读书活动总结
2014/05/07 职场文书
运动会广播稿50字-100字
2014/10/11 职场文书
MySQL实现用逗号进行拼接、以逗号进行分割
2022/12/24 MySQL