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

2024-08-31 19:58

本文主要是介绍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": "上海"

}

这篇关于Express实现路由分发控制、RESTful API的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1124859

相关文章

MySQL中On duplicate key update的实现示例

《MySQL中Onduplicatekeyupdate的实现示例》ONDUPLICATEKEYUPDATE是一种MySQL的语法,它在插入新数据时,如果遇到唯一键冲突,则会执行更新操作,而不是抛... 目录1/ ON DUPLICATE KEY UPDATE的简介2/ ON DUPLICATE KEY UP

Python中Json和其他类型相互转换的实现示例

《Python中Json和其他类型相互转换的实现示例》本文介绍了在Python中使用json模块实现json数据与dict、object之间的高效转换,包括loads(),load(),dumps()... 项目中经常会用到json格式转为object对象、dict字典格式等。在此做个记录,方便后续用到该方

JWT + 拦截器实现无状态登录系统

《JWT+拦截器实现无状态登录系统》JWT(JSONWebToken)提供了一种无状态的解决方案:用户登录后,服务器返回一个Token,后续请求携带该Token即可完成身份验证,无需服务器存储会话... 目录✅ 引言 一、JWT 是什么? 二、技术选型 三、项目结构 四、核心代码实现4.1 添加依赖(pom

SpringBoot路径映射配置的实现步骤

《SpringBoot路径映射配置的实现步骤》本文介绍了如何在SpringBoot项目中配置路径映射,使得除static目录外的资源可被访问,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一... 目录SpringBoot路径映射补:springboot 配置虚拟路径映射 @RequestMapp

Python与MySQL实现数据库实时同步的详细步骤

《Python与MySQL实现数据库实时同步的详细步骤》在日常开发中,数据同步是一项常见的需求,本篇文章将使用Python和MySQL来实现数据库实时同步,我们将围绕数据变更捕获、数据处理和数据写入这... 目录前言摘要概述:数据同步方案1. 基本思路2. mysql Binlog 简介实现步骤与代码示例1

Redis实现高效内存管理的示例代码

《Redis实现高效内存管理的示例代码》Redis内存管理是其核心功能之一,为了高效地利用内存,Redis采用了多种技术和策略,如优化的数据结构、内存分配策略、内存回收、数据压缩等,下面就来详细的介绍... 目录1. 内存分配策略jemalloc 的使用2. 数据压缩和编码ziplist示例代码3. 优化的

基于C#实现PDF转图片的详细教程

《基于C#实现PDF转图片的详细教程》在数字化办公场景中,PDF文件的可视化处理需求日益增长,本文将围绕Spire.PDFfor.NET这一工具,详解如何通过C#将PDF转换为JPG、PNG等主流图片... 目录引言一、组件部署二、快速入门:PDF 转图片的核心 C# 代码三、分辨率设置 - 清晰度的决定因

Java Kafka消费者实现过程

《JavaKafka消费者实现过程》Kafka消费者通过KafkaConsumer类实现,核心机制包括偏移量管理、消费者组协调、批量拉取消息及多线程处理,手动提交offset确保数据可靠性,自动提交... 目录基础KafkaConsumer类分析关键代码与核心算法2.1 订阅与分区分配2.2 拉取消息2.3

SpringBoot集成XXL-JOB实现任务管理全流程

《SpringBoot集成XXL-JOB实现任务管理全流程》XXL-JOB是一款轻量级分布式任务调度平台,功能丰富、界面简洁、易于扩展,本文介绍如何通过SpringBoot项目,使用RestTempl... 目录一、前言二、项目结构简述三、Maven 依赖四、Controller 代码详解五、Service

Python 基于http.server模块实现简单http服务的代码举例

《Python基于http.server模块实现简单http服务的代码举例》Pythonhttp.server模块通过继承BaseHTTPRequestHandler处理HTTP请求,使用Threa... 目录测试环境代码实现相关介绍模块简介类及相关函数简介参考链接测试环境win11专业版python