工程目录

如图所示,工程目录如下:

我们在工程下新建src的目录,src目录下新建三个文件夹:

  • controller:交互数据放到该目录下;
  • model:model类放到该目录下;
  • router:路由(模块接口处理)放到该目录下。

model目录

我们在model目录下,新建一个resModel.js,代码如下:

class BaseModel {
constructor(data,message) {
if(typeof data === 'string') {
this.message = data;
data = null;
message = null;
} if(data) {
this.data = data;
}
if(message) {
this.message = message;
}
}
} class SuccessModel extends BaseModel {
constructor(data,message) {
super(data,message);
this.errno = 0;
}
} class ErrorModel extends BaseModel {
constructor(data,message) {
super(data,message);
this.errno = -1;
}
} module.exports = {
SuccessModel,
ErrorModel
}

其作用就是对接口返回的数据做下拦截处理,对于返回成功或者失败的接口,我们除了返回响应的message,再整体添加一个errno状态码,其中errno返回0表示成功;errno返回-1表示失败。

controller目录

我们在controller目录下新建两个js的文件,把开发的这个博客项目分成两个模块:

  • blog.js:(博客列表、添加博客、更新博客、删除博客、博客详情
  • user.js:(目前只有登录)

当前两个的模块的数据都是假数据,blog.js代码如下:

// 获取博客列表
const getList = (keyword, author) => {
// 返回假数据
return [
{
id: 1,
title: '标题A',
content: '博客内容A',
createTime: 1630630964139,
author: 'zhangsan'
},
{
id: 2,
title: '标题B',
content: '博客内容B',
createTime: 1630630999550,
author: 'lisi'
}
]
} // 获取博客详情
const getDetail = (id) => {
// 返回假数据
return {
id: 1,
title: '标题A',
content: '博客内容A',
createTime: 1630630964139,
author: 'zhangsan'
}
} // 新建博客
const newBlog = (blogData = {}) => {
return {
id: 3
}
} // 更新博客
const updateBlog = (id) => {
return true;
} // 删除博客
const delBlog =(id) => {
return true;
} module.exports = {
getList,
getDetail,
newBlog,
updateBlog,
delBlog
}

user.js代码如下:

const loginCheck = (username,password) => {
// 使用假数据
if(username === 'zhangsan' && password === '123') {
return true;
}
return false;
} module.exports = {
loginCheck
}

router目录

router目录下也是分成两个路由模块:

  • blog.js:博客相关的路由接口处理操作;
  • user.js:用户相关(目前只有登录接口)的路由接口处理操作。

blog.js代码如下:

const { getList, getDetail, newBlog,updateBlog,delBlog } = require('../controller/blog');
const { SuccessModel, ErrorModel } = require('../model/resModel'); const handleBlogRouter = (req, res) => {
const method = req.method;
const id = req.query.id;
// 获取博客列表
if (method === 'GET' && req.path === '/api/blog/list') {
let keyword = req.query.keyword;
let author = req.query.author;
let resData = getList(keyword, author);
return new SuccessModel(resData)
} // 获取博客详情
if (method === 'GET' && req.path === '/api/blog/detail') {
let id = req.query.id;
let resData = getDetail(id);
return new SuccessModel(resData);
} // 新建博客
if (method === 'POST' && req.path === '/api/blog/new') {
const data = newBlog(req.body);
return new SuccessModel(data);
} // 更新博客
if (method === 'POST' && req.path === '/api/blog/update') {
const result = updateBlog(id);
if(result) {
return new SuccessModel();
} else {
return new ErrorModel('更新博客失败');
}
} // 删除博客
if (method === 'POST' && req.path === '/api/blog/del') {
const result = delBlog(id);
if(result) {
return new SuccessModel();
} else {
return new ErrorModel('删除博客失败');
}
}
} module.exports = handleBlogRouter;

user.js代码如下:

const { loginCheck } = require('../controller/user');
const { SuccessModel, ErrorModel } = require('../model/resModel'); const handleUserRouter = (req,res) => {
const method = req.method; // 登录
if(method === 'POST' && req.path === '/api/user/login') {
const { username,password } = req.body;
const result = loginCheck(username,password);
if(result) {
return new SuccessModel();
} else {
return new ErrorModel('登录失败');
}
}
} module.exports = handleUserRouter;

app.js

对node服务的处理代码如下:

const querystring = require('querystring');
const handleBlogRouter = require('./src/router/blog');
const handleUserRouter = require('./src/router/user'); // 处理post data
const getPostData = (req) => {
return new Promise((resolve,reject) => {
if(req.method !== 'POST') {
resolve({});
return;
}
if(req.headers['content-type'] !== 'application/json') {
resolve({});
return;
}
let postData = '';
req.on('data', chunk => {
postData += chunk.toString();
})
req.on('end', () => {
if(!postData) {
resolve({});
return;
}
resolve(JSON.parse(postData));
})
})
} const serverHandle = (req,res) => {
res.setHeader('Content-type','application/json'); // 获取path
const url = req.url;
req.path = url.split('?')[0]; req.query = querystring.parse(url.split('?')[1]); // 处理post data
getPostData(req).then(postData => {
req.body = postData; // 处理blog路由
const blogData = handleBlogRouter(req,res);
if(blogData) {
res.end(JSON.stringify(blogData));
return;
} // 处理user路由
const userData = handleUserRouter(req,res);
if(userData) {
res.end(JSON.stringify(userData));
return;
} // 未命中路由 返回404
res.writeHead(404, {'Content-type': 'text/plain'});
res.write('404 not found \n');
res.end();
})
} module.exports = serverHandle;

Node.js开发博客项目笔记-初始化路由(博客列表、新增、更新、删除、详情、登录)(3)的更多相关文章

  1. 《node.js开发指南》读书笔记(一)

    在开发时如果修改了js内容,不能通过刷新浏览器直接看到效果,必须通过重启nodejs程序才能看到,这样显然不利于开发调试,supervisor可以实现这个功能,监视对代码的改动,并自动重启nodejs ...

  2. 学习Nodejs:《Node.js开发指南》微博项目express2迁移至express4过程中填的坑

    <Node.js开发指南>项目地址https://github.com/BYVoid/microblog好不容易找到的基础版教程,但书中是基于express2的,而现在用的是express ...

  3. 基于.NetCore开发博客项目 StarBlog - (4) markdown博客批量导入

    系列文章 基于.NetCore开发博客项目 StarBlog - (1) 为什么需要自己写一个博客? 基于.NetCore开发博客项目 StarBlog - (2) 环境准备和创建项目 基于.NetC ...

  4. 《Node.js开发实战详解》学习笔记

    <Node.js开发实战详解>学习笔记 ——持续更新中 一.NodeJS设计模式 1 . 单例模式 顾名思义,单例就是保证一个类只有一个实例,实现的方法是,先判断实例是否存在,如果存在则直 ...

  5. Node.js学习笔记——Node.js开发Web后台服务

    一.简介 Node.js 是一个基于Google Chrome V8 引擎的 JavaScript 运行环境.Node.js 使用了一个事件驱动.非阻塞式 I/O 的模型,使其轻量又高效.Node.j ...

  6. Nodejs学习笔记(一)--- 简介及安装Node.js开发环境

    目录 学习资料 简介 安装Node.js npm简介 开发工具 Sublime Node.js开发环境配置 扩展:安装多版本管理器 学习资料 1.深入浅出Node.js http://www.info ...

  7. Nodejs学习笔记(一)—简介及安装Node.js开发环境

    一.简介 Node.js是让Javascript脱离浏览器运行在服务器的一个平台,不是语言: Node.js采用的Javascript引擎是来自Google Chrome的V8:运行在浏览器外不用考虑 ...

  8. ES6 学习笔记 (2)-- Liunx环境安装Node.js 与 搭建 Node.js 开发环境

    笔记参考来源:廖雪峰老师的javascript全栈教程 一.安装Node.js 目前Node.js的最新版本是6.2.x.首先,从Node.js官网下载对应平台的安装程序. 1.下载 选择对应的Liu ...

  9. mac下配置Node.js开发环境、express安装、创建项目

    mac下配置Node.js开发环境.express安装.创建项目 一.node.js的安装 去官网下载对应的平台版本就可以了,https://nodejs.org 二.express安装 sudo n ...

  10. 【转】Nodejs学习笔记(一)--- 简介及安装Node.js开发环境

    目录 学习资料 简介 安装Node.js npm简介 开发工具 Sublime Node.js开发环境配置 扩展:安装多版本管理器 学习资料 1.深入浅出Node.js http://www.info ...

随机推荐

  1. Python爬取小说+Servlet+C3P0+MVC构建小说api

    一.摘要: 使用python爬取网络小说数据存入数据库,利用C3P0数据库连接池获取数据库数据,采用MVC三层架构对数据库数据进行操作,输出JSON格式数据到前端页面 二.内容: 1.gitee外链消 ...

  2. 自动修改网卡 IP

    1. 讲个故事 我的一同事需要调试 PLC,需要经常修改电脑 IP 在各个工位的 PLC 间来回连接.于是,每次需要改变 IP 的时候都是手动点开网络管理界面然后再修改.终于有一天,一天改 80 次 ...

  3. 深入解读RabbitMQ工作原理

    RabbitMQ简介 在介绍RabbitMQ之前首先要介绍一下MQ,MQ是什么?MQ全称是Message Queue,可以理解为消息队列的意思. RabbitMQ是一个实现了AMQP(Advanced ...

  4. 【译】使 Visual Studio 更加可视化

    任何 Web.桌面或移动开发人员都经常使用图像.你可以从 C#.HTML.XAML.CSS.C++.VB.TypeScript 甚至代码注释中引用它们.有些图像是本地的,有些存在于线上或网络共享中,而 ...

  5. 指针_C

    指针的代码 // Code file created by C Code Develop #include "ccd.h" #include "stdio.h" ...

  6. 交叉熵、KL 散度 | 定义与相互关系

    1 KL 散度 对于离散概率分布 \(P\) 和 \(Q\) ,KL 散度定义为: \[\text{KL}(P \| Q) = -E_{x\sim P}\log P(x)-\log Q(x) \\ = ...

  7. win10安装和使用wireshark

    win10安装和使用wiresharkhttps://blog.csdn.net/qq_34732729/article/details/105126146https://blog.csdn.net/ ...

  8. AI/机器学习(计算机视觉/NLP)方向面试复习1

    1. 判断满二叉树 所有节点的度要么为0,要么为2,且所有的叶子节点都在最后一层. #include <iostream> using namespace std; class TreeN ...

  9. 7月24号python:库存管理

    7月24号python:库存管理 题目: ​ 仓库管理员以数组 stock 形式记录商品库存表.stock[i] 表示商品 id,可能存在重复.原库存表按商品 id 升序排列.现因突发情况需要进行商品 ...

  10. Http、Https简介和Session、token的请求流程

    Http Http (超文本输出协议) 是一种分布式.协作式和超媒体信息系统的应用层协议,它通常运行在TCP之上,因特网应用最广泛的便是Http协议,所有www都遵循这个标准.主要用于Web 浏览器与 ...