文章目录:

环境和结构 

一:初始化

1.创建项目

2. 配置cors跨域

3.配置解析表单数据的中间件

4.初始化用户路由模块

5.抽离用户路由模块中的处理函数

二:数据库连接项目

1.在数据库中新建表

2.安装并配置mysql模块

三:验证表单数据

四:逻辑代码

参考:api_server_ev;编写好代码的接口后,可以写对应的API接口文档

环境和结构 

软件:VScode、Postman、Node.js、MySQL

结构 

api_server 文件夹:项目根目录

   app.js文件:项目的入口

   router文件夹:路由模块,存放客户端的请求与处理函数之间的映射关系

user.js文件:用户的路由模块

   router_handler文件夹:路由处理函数模块

user.js文件:用户的路由处理函数模块

   db文件夹:数据库相关

index.js 文件:创建数据库的连接对象

   schema:验证规则模块

user.js 

一:初始化

1.创建项目

第一步:根目录下初始化包管理配置文件

npm init -y

第二步:安装特定版本的 express

npm i express@4.17.1

第三步:app.js初始化【app.js】

// 导入 express 模块

const express = require('express')

// 创建 express 的服务器实例

const app = express()

// 调用 app.listen 方法,指定端口号并启动web服务器

app.listen(3007, function () {

console.log('api server running at http://127.0.0.1:3007')

})

2. 配置cors跨域

第一步:安装 cors 中间件

npm i cors@2.8.5

第二步:app.js 中导入并配置 cors 中间件【app.js】

// 导入 cors 中间件

const cors = require('cors')

// 将 cors 注册为全局中间件

app.use(cors())

3.配置解析表单数据的中间件

app.use(express.urlencoded({ extended: false }))

4.初始化用户路由模块

第一步:/router/user.js文件用户的路由模块始化【/router/user.js】

const express = require('express')

// 创建路由对象

const router = express.Router()

//导入用户路由处理函数模块

const userHandler = require('../router_handler/user')

//导入文章分类的路由处理函数模块

const artcate_handler = require('../router_handler/artcate')

// 注册新用户

router.post('/reguser', userHandler.regUser)

// 登录

router.post('/login', userHandler.login)

// 获取用户的基本信息

router.get('/userinfo', (req, res) => {

res.send('ok')

})

// 获取文章分类的列表数据

router.get('/cates', artcate_handler.getArticleCates)

// 导入验证数据合法性的中间件

const expressJoi = require('@escook/express-joi')

// 导入需要的验证规则对象

const { update_userinfo_schema, update_password_schema } = require('../schema/user')

// 更新用户的基本信息

router.post('/userinfo', expressJoi(update_userinfo_schema), userinfo_handler.updateUserInfo)

router.post('/updatepwd', expressJoi(update_password_schema), userinfo_handler.updatePassword)

// 将路由对象共享出去

module.exports = router

第二步:在 app.js 中导入并使用 用户路由模块【app.js】

// 导入并注册用户路由模块

const userRouter = require('./router/user')

app.use('/api', userRouter)

// 导入并使用用户信息路由模块

const userinfoRouter = require('./router/userinfo')

// 注意:以 /my 开头的接口,都是有权限的接口,需要进行 Token 身份认证

app.use('/my', userinfoRouter)

5.抽离用户路由模块中的处理函数

在 /router_handler/user.js 中,使用 exports 对象,分别向外共享如下两个 路由处理函数【/router_handler/user.js】

/**

* 在这里定义和用户相关的路由处理函数,供 /router/user.js 模块进行调用

*/

// 注册用户的处理函数

exports.regUser = (req, res) => {

res.send('reguser OK')

}

// 登录的处理函数

exports.login = (req, res) => {

res.send('login OK')

}

二:数据库连接项目

1.在数据库中新建表

2.安装并配置mysql模块

第一步:安装 mysql模块

npm i mysql@2.18.1

第二步:index.js创建数据库的连接对象【index.js】

// 导入 mysql 模块

const mysql = require('mysql')

// 创建数据库连接对象

const db = mysql.createPool({

host: '127.0.0.1',

user: 'root',

password: '密码',

database: '数据库名',

})

// 向外共享 db 数据库连接对象

module.exports = db

第三步:从/router_handler/user.js数据库获取信息【/router_handler/user.js】

// 导入数据库操作模块

const db = require('../db/index')

//定义 SQL 语句

const sql = `select id, username, nickname, email, user_pic from ev_users where id=?`

//调用 db.query() 执行 SQL 语句

// 注意:req 对象上的 user 属性,是 Token 解析成功,express-jwt 中间件帮我们挂载上去的

db.query(sql, req.user.id, (err, results) => {

// 1. 执行 SQL 语句失败

if (err) return res.cc(err)

// 2. 执行 SQL 语句成功,但是查询到的数据条数不等于 1

if (results.length !== 1) return res.cc('获取用户信息失败!')

// 3. 将用户信息响应给客户端

res.send({

status: 0,

message: '获取用户基本信息成功!',

data: results[0],

})

})

三:验证表单数据

在 /schema/user.js 验证规则模块中【 /schema/user.js】

// 定义 id, nickname, emial 的验证规则

const id = joi.number().integer().min(1).required()

const nickname = joi.string().required()

const email = joi.string().email().required()

//并使用 exports 向外共享如下的 验证规则对象

// 验证规则对象 - 更新用户基本信息

exports.update_userinfo_schema = {

body: {

id,

nickname,

email,

},

}

四:逻辑代码

相关代码

参考阅读

评论可见,请评论后查看内容,谢谢!!!
 您阅读本篇文章共花了: