Node.js开发博客项目笔记-初始化路由(博客列表、新增、更新、删除、详情、登录)(3)
工程目录
如图所示,工程目录如下:

我们在工程下新建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)的更多相关文章
- 《node.js开发指南》读书笔记(一)
在开发时如果修改了js内容,不能通过刷新浏览器直接看到效果,必须通过重启nodejs程序才能看到,这样显然不利于开发调试,supervisor可以实现这个功能,监视对代码的改动,并自动重启nodejs ...
- 学习Nodejs:《Node.js开发指南》微博项目express2迁移至express4过程中填的坑
<Node.js开发指南>项目地址https://github.com/BYVoid/microblog好不容易找到的基础版教程,但书中是基于express2的,而现在用的是express ...
- 基于.NetCore开发博客项目 StarBlog - (4) markdown博客批量导入
系列文章 基于.NetCore开发博客项目 StarBlog - (1) 为什么需要自己写一个博客? 基于.NetCore开发博客项目 StarBlog - (2) 环境准备和创建项目 基于.NetC ...
- 《Node.js开发实战详解》学习笔记
<Node.js开发实战详解>学习笔记 ——持续更新中 一.NodeJS设计模式 1 . 单例模式 顾名思义,单例就是保证一个类只有一个实例,实现的方法是,先判断实例是否存在,如果存在则直 ...
- Node.js学习笔记——Node.js开发Web后台服务
一.简介 Node.js 是一个基于Google Chrome V8 引擎的 JavaScript 运行环境.Node.js 使用了一个事件驱动.非阻塞式 I/O 的模型,使其轻量又高效.Node.j ...
- Nodejs学习笔记(一)--- 简介及安装Node.js开发环境
目录 学习资料 简介 安装Node.js npm简介 开发工具 Sublime Node.js开发环境配置 扩展:安装多版本管理器 学习资料 1.深入浅出Node.js http://www.info ...
- Nodejs学习笔记(一)—简介及安装Node.js开发环境
一.简介 Node.js是让Javascript脱离浏览器运行在服务器的一个平台,不是语言: Node.js采用的Javascript引擎是来自Google Chrome的V8:运行在浏览器外不用考虑 ...
- ES6 学习笔记 (2)-- Liunx环境安装Node.js 与 搭建 Node.js 开发环境
笔记参考来源:廖雪峰老师的javascript全栈教程 一.安装Node.js 目前Node.js的最新版本是6.2.x.首先,从Node.js官网下载对应平台的安装程序. 1.下载 选择对应的Liu ...
- mac下配置Node.js开发环境、express安装、创建项目
mac下配置Node.js开发环境.express安装.创建项目 一.node.js的安装 去官网下载对应的平台版本就可以了,https://nodejs.org 二.express安装 sudo n ...
- 【转】Nodejs学习笔记(一)--- 简介及安装Node.js开发环境
目录 学习资料 简介 安装Node.js npm简介 开发工具 Sublime Node.js开发环境配置 扩展:安装多版本管理器 学习资料 1.深入浅出Node.js http://www.info ...
随机推荐
- 如何优雅地使用Mybatis逆向工程生成类
文/朱季谦 1.环境:SpringBoot 2.在pom.xml文件里引入相关依赖: 1 <plugin> 2 <groupId>org.mybatis.generator&l ...
- 做独立开发者,能在 AppStore 赚到多少钱?
成为一名独立开发者,不用朝九晚五的上班,开发自己感兴趣的产品,在AppStore里赚美金,这可能是很多程序员的梦想,今天就来盘一盘,这个梦想实现的概率有多少. (Solo社区 投稿) 先来了解一些数据 ...
- .NET周刊【7月第2期 2024-07-14】
国内文章 开源GTKSystem.Windows.Forms框架让C# winform支持跨平台运行 https://www.cnblogs.com/easywebfactory/p/18289178 ...
- Swift开发基础07-内存布局
了解Swift的内存布局和底层原理对于编写高性能和内存高效的应用非常重要.接下来,我将更详细地介绍Swift的内存管理机制和一些底层实现细节,包括内存布局.ARC(自动引用计数).引用类型和值类型的区 ...
- “智能体风”吹进体育圈 粉丝手搓上百个智能体为中国健儿应援 太有AI了!粉丝手搓上百个智能体为中国健儿打CALL
智能体的风吹进了体育竞技圈.近日,在百度文心智能体平台,出现了上百个充满"AI"的运动明星粉丝应援智能体,比如支持中国女子乒乓球运动员孙颖莎的"孙颖莎的小迷妹" ...
- Jmeter二次开发函数之入门
背景:Jmeter不能满足我们的参数需求,如生成手机号码.身份证号码等业务,固对jmeter进行二次函数开发. jmeter提供了接口供用户进行二次开发,我们只需引入包进行编辑.从jmeter规范上, ...
- 【JS】06 语法补充
严格模式(use strict) 其实就是就是对JS随意的语法做一个强制规范要求 开启严格模式: "use strict"; 注意,只有在第一行声明才会有效,. 否则在严格模式之前 ...
- 【Lodop】02 C-Lodop手册阅读上手
版本:4.0.6.2 一.概述 C-Lodop云打印是一款精巧快捷的云打印服务产品,以Lodop功能语句为基础,JS语句实现远程打印 移动设备+Wifi+普通打印机+集中打印 C-Lodop对客户端浏 ...
- Human-centric Computing and Information Sciences期刊基本信息
letpub 地址: https://www.letpub.com.cn/index.php?page=journalapp&view=detail&journalid=10450&a ...
- Java RMI技术详解与案例分析
Java RMI(Remote Method Invocation)是一种允许Java虚拟机之间进行通信和交互的技术.它使得远程Java对象能够像本地对象一样被访问和操作,从而简化了分布式应用程序的开 ...