当前位置: 首页 > news >正文

记录:express router,可以让node.js后端文件里的路由分布的更清晰

假设我们有一个server.js,里面的内容用于响应客户端的fetch请求,如果fetch请求很少,我们通常会把所有内容写到server.js里,例如:

const server = express();server.post("/api/v1/sendgraindata", (req, res)...server.get("/api/v1/guarddata", (req, res)...server.get("/api/v1/skytemphudivalue", (req, res)....server.post("/api/v1/startstopinner", (req, res)........

但是,这样把数据操作与控制操作混杂在一起了,而且如果需要fetch的请求特别多,就很难寻找想要修改的内容了,所以为了更清晰一些,我们可以这样:

一个完整的小server.js:

const fs = require("fs");const path = require("path");const cors = require("cors");const express = require("express");//''''''''''''''''''''''''''''''''''   导入路由  ''''''''''''''''''''''''''''''''''''''''''''const commRouters = require("./routers/commRouter");         //公用路由  routes文件夹下的commRouter.js文件const storeRouters = require("./routers/storeRouter");             //数据路由  routes文件夹下的storeRouter.js文件const measureRouters = require("./routers/measureRouter"); //控制路由 routes文件夹下的measureRouter.js文件//'''''''''''''''''''''''''''''''''''' ''''''''''''''''''''''''''''''''''''''''''const server = express();//''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''server.use(express.json());server.use(express.urlencoded({ extended: true }));server.use(cors());server.use(express.static(path.join(__dirname, "/public")));//''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''server.use("/api/v1/comm", commRouters);server.use("/api/v1/store", storeRouters);server.use("/api/v1/measure", measureRouters);//''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''const port = fs.readFileSync(path.join(__dirname, "/port.txt"), "utf-8");//监听http请求端口server.listen(port, () => {console.log(`listening on port ${port}...`);});

1 commRouter.js:

const express = require("express");

const commRouter = express.Router();

commRouter.get("/userbycodepassword", (req, res) => {

  .....

  });

});

module.exports = commRouter;

2 storeRouter.js:

const express = require("express");

const storeRouter = express.Router();

storeRouter.get("/storebystorename", (req, res) => {

});

storeRouter.delete("/storebyid", (req, res) => {

...

});

storeRouter.put("/weatherstationinfo", (req, res) => {

....

});

storeRouter.put("/updatestorebyid", (req, res) => {

...  

});

module.exports = storeRouter;

3 measureRouter.js

const express = require("express");

const measureRouter = express.Router();

const net = require("net"); 

measureRouter.put("/plcdevice", (req, res) => {

 ...

});

measureRouter.get("/plcdevice", (req, res) => {

});

1 客户端fetch:

const res = await fetch(

    `${serverAddress}/api/v1/comm/userbycodepassword?code=${code}&&password=${password}`

  );

将自动由后端的commRouter.js处理

2 客户端fetch:

 const res = await fetchWithTimeout(

    `${serverAddress}/api/v1/measure/rtuskystoretemphudi?branchnum=${branchNum}&&address=${address}&&count=${count}&&waitbytes=${waitbytes}&&ip=${ip}`,

    options

  );

将自动由后端的measureRouter.js处理

把server.js里的路由分到多个文件里处理,将使得主文件更清晰,查找路由更方便.

fetchWithTimeout用于在循环里fetch,闲下来时作为另一个话题写.

相关文章:

  • 【Node.js】工具链与工程化
  • VR 航天科普,沉浸式体验宇宙奥秘​
  • iOS工厂模式
  • 基于 ZigBee 的 LED 路灯智能控制器的设计
  • 杨校老师竞赛课之青科赛GOC5-6年级组模拟题
  • ESP32-S3 使用SPI-TFT_eSPI与ST7789驱动通信
  • HTTP Digest 认证:原理剖析与服务端实现详解
  • Ubuntu下误删除分区的补救
  • 排序和排列——蓝桥杯备考
  • 供应链管理:联合国/我国 41个产业/工业大类包括什么/代表公司
  • 【C++】控制台小游戏
  • HarmonyOS NEXT~鸿蒙系统下的Cordova框架应用开发指南
  • 人工智能在工业自动化中的应用与未来趋势
  • 【IDEA问题】springboot本地启动应用报错:程序包不存在;找不到符号
  • Vue:axios(GET请求)
  • leetcode 148. Sort List
  • ThreadLocal线程本地变量在dubbo服务使用时候遇到的一个坑
  • 深入剖析 5G 核心网中的 PLMN
  • Android 直播播放器FFmpeg静态库编译实战指南(NDK r21b)
  • 彩礼的异化:婚姻市场中的资本规训与性别政治批判
  • 毕设做网站太简单/志鸿优化网官网
  • 专业定制网站建设/百度网址大全 简单版
  • 盘石 网站建设/博客网站注册
  • 计算机专业的会学怎么做网站吗/千万不要做手游推广员
  • python做网站有优势/seo主要是指优化
  • 专门做搞笑视频的网站/东莞seo整站优化