Express实现路由分发控制、RESTful API

Express实现路由分发控制、RESTful API

标签(空格分隔): Node.js


最近在用Express作为自己的WEB应用框架,其中最为迷惑的就是Express的路由控制和分发,在网上搜了很多资料,但是大部分的资料都是将Express的路由控制写在了app.js入口文件中,但是这样的写法写一些Demo是可以的,但是在实战项目中基本上不会这样来写,因为随着项目的庞大,在app.js入口文件中的路由控制将会越来越复杂。所以,我们实际项目中一般会将不同的业务逻辑交给不同的模块开负责。

以下是这几天摸索出来的一些简单实现

如果有大神有更好的实现方案或建议,欢迎给予指点

具体实现方式如下

本Demo的目录结构如下

- node-modules

- api

- user.js

- routes

- index.js

- app.js

- package.json

创建Node.js应用

首先通过cd进入到项目希望放置的目录,然后执行以下命令

npm init -y

执行完以后,会在目录中创建一个package.json配置文件,打开该文件,在配置文件中添加项目中所需要的所有依赖。(我个人的搭配是Express+redis数据库),添加完以后的package.json文件如下

{

"name": "RestfulDocApi",

"version": "1.0.0",

"description": "",

"main": "app.js",

"scripts": {

"test": "echo \"Error: no test specified\" && exit 1"

},

"keywords": [],

"author": "",

"license": "ISC",

"dependencies":{

"express":"^4.13.4", // express框架

"redis":"^2.5.2", // redis数据库

"body-parser": "~1.0.1", // 用于解析提交的请求表单

"response-time": "^2.3.1" // 计算响应时间中间件

}

}

安装Express框架及其依赖

编辑完以后,进入到该目录,然后执行以下命令安装Express框架及其依赖

npm install

注意

由于国内被墙,这个过程如果依赖包过多或过大的时候,会非常慢,所以,建议使用淘宝的cnpm来安装(不安装也可以,只是会比较慢)

  • 安装cnpm

npm install -g cnpm

  • 然后通过cnpm安装Express框架及其依赖

cnpm install

创建入口文件app.js

在根目录创建app.js并添加以下代码

/**

* app.js

* @authors 袁俊亮 (1610712512@qq.com)

* @date 2016-12-09 16:57:54

* @webSite http://www.yuanjunliang.cc

*/

 

var app = require('express')();

var responseTime = require('response-time');

var redis = require('redis');

 

// 创建数据库客户端

var client = redis.createClient();

client.on('error',function(err){

console.log('error'+err);

});

 

// 设置端口

app.set('port',(process.env.PORT || 3000));

 

// 使用请求计时模块

app.use(responseTime());

 

// 设置/routes/index文件为总的路由控制文件

// 在routes/index文件中再进行统一的路由分发,这样防止app.js中代码过于臃肿

var routes = require('./routes/index');

routes(app);

 

// 启动服务的时候监听端口号

app.listen(app.get('port'),function(){

console.log('Server listening on port:',app.get('port'));

});

实现路由分发控制文件/routes/index.js

创建路由分发控制文件/routes/index.js,在该文件中,实现将用户所有的请求逻辑处理分发到不同的业务模块进行处理。实现代码如下

module.exports = function(app){

// 分发user模块,比如用户的注册和登录请求业务逻辑将会在/api/user.js中实现

var user = require('../api/user');

app.use('/user',user);

};

处理具体的业务逻辑(与数据库相关的业务逻辑处理都在这里完成)

创建一个/api目录下的user.js文件,在其中实现user模块的业务逻辑处理,代码如下

/**

* 用户模块user.js

* @authors 袁俊亮 (1610712512@qq.com)

* @date 2016-12-09 17:06:42

* @webSite http://www.yuanjunliang.cc

*/

 

var express = require('express');

var router = express.Router();

 

// 处理get请求

router.get('/', function(req, res) {

res.send({

'username':'john',

'sex':'man',

'address':'上海'

});

});

 

// 处理POST请求

router.post('/',function(req,res){

console.log('接受到了post请求');

res.send({

'regist':{title:req.param('username')}

})

});

 

module.exports = router;

经过上诉的处理以后就完成了user模块的路由控制分发,每当用户发起与user相关的请求时,就可以在/api/user.js中接收到用户的相关请求,并做相关处理

业务逻辑扩展

其他的分发逻辑类似,比如在添加一个文章编辑和查看模块

  • 在/api目录下创建一个post.js文件并在其中实现文章的业务逻辑处理

  • 在/routes/index.js文件中添加一条路由规则如下

module.exports = function(app){

// 分发user模块,比如用户的注册和登录请求业务逻辑将会在/api/user.js中实现

var user = require('../api/user');

app.use('/user',user);

// 文章编辑及查看路由模块

var post = requier('../api/post');

app.use('/post',post);

};

最后给出上诉项目的Demo源码

源码地址为:

链接: https://pan.baidu.com/s/1c2kPYCS 密码: ni3r

源码使用方法

  • 解压源码

解压完源码以后通过终端cd到本项目中,然后执行npm install安装所有的依赖。

  • 启动服务

node app.js

如果终端中返回一下信息,说明启动成功

Server listening on port: 3000

  • 在浏览器中访问

http://localhost:3000/user

如果返回一下json数据,说明请求成功

{

"username": "john",

"sex": "man",

"address": "上海"

}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/248913.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

springboot运行jar包时候加载指定目录的其他jar支持包

最近发生一个小故障,调试好的项目,发布成jar包后无法找到oracle的驱动,研究了一下解决了。记录一下。写了一个run.sh脚本 #!/bin/bash cd ~ cd app nohup java -Djava.ext.dirs./lib -Doracle.jdbc.thinLogonCapabilityo3 -jar -Xms512m -Xmx…

OpenLayers3关于Map Export的Canvas跨域

一 Canvas跨域现象 地图导出是地图中常用的功能,并且OpenLayers3中也提供了两个地图导出的例子:http://openlayers.org/en/latest/examples/export-map.html http://openlayers.org/en/latest/examples/export-pdf.html。 看到这两个例子我们都很兴奋,直…

typescript-koa-postgresql 实现一个简单的rest风格服务器 —— 连接 postgresql 数据库...

接上一篇,这里使用 sequelize 来连接 postgresql 数据库 1、安装 sequelize,数据库驱动 pg yarn add sequelize sequelize-typescript pg reflect-metadata 2、新建配置文件夹 conf 及 配置文件 db.conf.ts /*** name: 数据库配置* param : undefined* r…

SmartGit使用教程

说明 官网的客户端是命令行形式的,有兴趣可以去了解下。这里针对图形界面的smartgit做一个使用说明。 软件下载和安装 下载地址[2016.12.16测试可以] 按需选择,如果不知道自己电脑是什么系统的,那我没话说了https://www.syntevo.com/smartgit/ 安装 …

jquery 下拉框 select2 运用 笔记

1,添加select2 样式 参考&#xff08;https://select2.org/ &#xff09; 2,Html: <select id"txtType" name"Type" class"form-control select2" multiple"multiple"> </select> 3,jquery section scripts{ $(documen…

Asp.Net MVC中Action跳转小结

首先我觉得action的跳转大致可以这样归一下类&#xff0c;跳转到同一控制器内的action和不同控制器内的action、带有参数的action跳转和不带参数的action跳转。 一、RedirectToAction(“Index”);//一个参数时在本Controller下&#xff0c;不传入参数。 二、RedirectToAction(A…

获取浏览器屏幕高度(js,jq) - 进击的小牛牛 - 博客园

javascript IE中&#xff1a; document.body.clientWidth > BODY对象宽度 document.body.clientHeight > BODY对象高度 document.documentElement.clientWidth > 可见区域宽度 document.documentElement.clientHeight > 可见区域高度 FireFox中&#xff1a; docum…

589-N叉树的前序遍历

N阶二叉树&#xff1a; class Tree {public int val;public List<Tree> children;public Tree() {}public Tree(int _val, List<Tree> _children) {val _val;children _children;}}迭代法遍历&#xff1a;public List<Integer> preorder(Tree root) {List&…

解析URL参数

1、拿到一个完整url后&#xff0c;如何解析该url得到里面的参数。 /*** 解析url中参数信息&#xff0c;返回参数数组*/ function convertUrlQuery($query) {$queryParts explode(&, $query);$params array();foreach ($queryParts as $param) {$item explode(, $param);…

第一个爬虫和测试

Python测试函数的方法之一是用&#xff1a;try……except def gameover(a,b):if a>10 and b>10 and abs(a-b)2:return Trueif (a>11 and b<11) or (a<11 and b>11):return Truereturn False try:agameover(10,11)print(a) except:print("Error") g…

JS组件系列——Bootstrap 树控件使用经验分享 - 懒得安分 - 博客园

前言&#xff1a;很多时候我们在项目中需要用到树&#xff0c;有些树仅仅是展示层级关系&#xff0c;有些树是为了展示和编辑层级关系&#xff0c;还有些树是为了选中项然后其他地方调用选中项。不管怎么样&#xff0c;树控件都是很多项目里面不可或缺的组件之一。今天&#xf…

算法第4章实践报告

1.实践题目&#xff1a;最小删数问题 2.问题描述&#xff1a;给定n位正整数a&#xff0c;去掉其中任意k≤n 个数字后&#xff0c;剩下的数字按原次序排列组成一个新 的正整数。对于给定的n位正整数a和正整数 k&#xff0c;设计一个算法找出剩下数字组成的新数最 小的删数方案。…

Vue 下拉刷新及无限加载组件 - 有你便是晴天 - 博客园

原文 https://github.com/wangdahoo/vue-scroller 主题 Vue.js Vue Scroller Vue Scroller is a foundational component ofVonic UI. In purpose of smooth scrolling, pull to refresh and infinite loading. Demo Change Logs v0.3.9 add getPosition method for scr…

用java编程实现集合的交、并、差和补运算

一、实验目的 掌握集合的交、并、差和补运算&#xff0c;并且使用计算机编程实现。 二、实验内容 通过编程实现求给定集合A和B的并集C&#xff08;CA∪B&#xff09;、交集C&#xff08;CA∩B&#xff09;、差集C&#xff08;CA-B&#xff09;、补集~CE-C的运算。 三、实验要求…

node.js项目中常量的配置 - 个人文章 - SegmentFault 思否

在项目中&#xff0c;我们常将一些常量信息做成配置项&#xff0c;如&#xff0c;数据库的链接配置&#xff0c;业务错误代码配资等等。 我们通过两种方式可以解决该问题。 系统环境变量的方式 配置文件的方式 下边&#xff0c;将以这两方面进行展开。 1. 系统环境变量 No…

MySQL create table语法中的key与index的区别

在create table的语句中&#xff0c;key和index混淆在一起&#xff0c;官方手册中的解释是这样&#xff1a; KEY is normally a synonym for INDEX. The key attribute PRIMARY KEY can also be specified as just KEY when given in a column definition. This was implemente…

蓝桥杯 历届试题 九宫重排 (bfs+康托展开去重优化)

Description 如下面第一个图的九宫格中&#xff0c;放着 1~8 的数字卡片&#xff0c;还有一个格子空着。与空格子相邻的格子中的卡片可以移动到空格中。经过若干次移动&#xff0c;可以形成第二个图所示的局面。我们把第一个图的局面记为&#xff1a;12345678.把第二个图的局面…

DIV或者DIV里面的图片水平与垂直居中的方法 - 站住,别跑 - 博客园

DIV或者DIV里面的图片水平与垂直居中的方法 <div class“box”><img /> </div> 水平居中的常用方式&#xff1a; text-align:center ——这可以实现子元素字体&#xff0c;图片的水平居中。 margin:0 auto —— 这是针对块元素的水平居中方法 垂直居中的常…

spring boot的多环境部署

需求&#xff1a;不同的环境有不同的开关属性&#xff0c;比如开发系统&#xff0c;需要关闭短信&#xff0c;微信的通知功能。而演示环境&#xff0c;线上环境则需要打开这些配置。 那么&#xff0c;如何做到呢&#xff1f;---》在properties.application配置 需要在resources…

mybatis之动态SQL操作之查询

1&#xff09; 查询条件不确定&#xff0c;需要根据情况产生SQL语法&#xff0c;这种情况叫动态SQL /*** 持久层* author AdminTC*/ public class StudentDao {/*** 动态SQL--查询*/public List<Student> dynaSQLwithSelect(String name,Double sal) throws Exception{S…