文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

node.js+postman+mongodb如何搭建测试注册接口

2023-07-02 08:28

关注

这篇文章主要讲解了“node.js+postman+mongodb如何搭建测试注册接口”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“node.js+postman+mongodb如何搭建测试注册接口”吧!

准备工作

申请一个免费的MongoDB

https://www.mlab.com注册申请一个500M的MongoDB数据库。登录后手动在创建Databases下的Collections中手动创建一个数据库node_app。

在个人首页点击Connect获取node.js连接MongoDB数据库的字符串为

mongodb+srv://<username>:<password>@cluster0.ylpaf.mongodb.net/node_app

将其中<username>:<password>修改为自己设定的数据库用户名和密码。

下载安装Postman

https://www.postman.com/注册一个账号,下载安装Postman agent,即可方便地进行GET/POST/PUT等测试。

mongodb连接串配置

安装mongoose用于连接数据库:

> npm install mongoose> > cd C:\Users\xiaoming\source\repos\node_demo\node_app> mkdir config> cd config> new-item keys.js -type file

编辑keys.js配置连接串:

module.exports = {    mongoURI: "mongodb+srv://<username>:<password>@cluster0.ylpaf.mongodb.net/node_app"}

编辑server.js入口文件:

const express = require("express");const mongoose = require("mongoose");const app = express();const db = require("./config/keys").mongoURI;mongoose.connect(db)        .then(() => console.log("MongoDB connected."))        .catch(err => console.log(err));app.get("/", (req, res) => {    res.send("Hello World!");})const port = process.env.PORT || 5000;app.listen(port, () => {    console.log(`Server running on port ${port}`);})

检查是否能连接到数据库:

> nodemon server.js[nodemon] 2.0.16[nodemon] to restart at any time, enter `rs`[nodemon] watching path(s): *.*[nodemon] watching extensions: js,mjs,json[nodemon] starting `node server.js`Server running on port 5000MongoDB connected.

数据库连接正常。

GET请求测试

创建路由文件

C:\Users\xiaoming\source\repos\node_demo\node_app\routes\api\users.js

编辑users.js并添加GET请求:

// login & registtrationconst express = require("express");const router = express.Router();router.get("/test", (req,res) => {    res.json({msg:"Login succeeded!"})})module.exports = router;

编辑server.js,导入并使用users.js:

const express = require("express");const mongoose = require("mongoose");const app = express();const users = require("./routes/api/users"); const db = require("./config/keys").mongoURI;mongoose.connect(db)    .then(() => console.log("MongoDB connected."))    .catch(err => console.log(err));// 设置app路由app.get("/", (req, res) => {    res.send("Hello World!");})// 使用usersapp.use("/api/users", users);const port = process.env.PORT || 5000;app.listen(port, () => {    console.log(`Server running on port ${port}`);})

访问

http://localhost:5000/api/users/test

可以看到

{"msg":"Login succeeded!"}

注册接口搭建

创建User数据模型

创建用户数据模型文件

C:\Users\xiaoming\source\repos\node_demo\node_app\models\User.js

编辑User.js创建用户数据模型:

const mongoose = require("mongoose");const Schema = mongoose.Schema;// create Schemaconst UserSchema = new Schema({    name:{        type: String,        required: true    },    email: {        type: String,        required: true    },    password: {        type: String,        required: true    },    avatar: {        type: String    },    date: {        type: Date,        default: Date.now    },})module.exports = User = mongoose.model("users", UserSchema);

使用body-parser中间件

安装body-parser中间件,可以方便地处理HTTP请求。

> npm install body-parser

编辑server.js使用body-parser:

const express = require("express");const mongoose = require("mongoose");const bodyParser = require("body-parser");const app = express();const users = require("./routes/api/users"); const db = require("./config/keys").mongoURI;app.use(bodyParser.urlencoded({ extended: false }));app.use(bodyParser.json());mongoose.connect(db)    .then(() => console.log("MongoDB connected."))    .catch(err => console.log(err));app.get("/", (req, res) => {    res.send("Hello World!");})app.use("/api/users", users);const port = process.env.PORT || 5000;app.listen(port, () => {    console.log(`Server running on port ${port}`);})

POST请求测试

编辑users.js增加POST请求:

// @login & registtrationconst express = require("express");const router = express.Router();router.get("/test", (req,res) => {    res.json({msg:"Login succeeded!"})})router.post("/register", (req, res) => {    console.log(req.body);})module.exports = router;

POST中暂时只有一个打印请求体的操作。

在Postman中的Workspace中测试:

POST http://localhost:5000/api/users/register

Body选择x-www-form-urlencoded,在KEY和VALUE中填入测试内容:

KEY         VALUEemail    harlie@google.com

查看终端输出:

Server running on port 5000
MongoDB connected.
[Object: null prototype] { email: 'harlie@google.com' }

说明成功获取到了req.body。

使用User数据模型

首先安装bcrypt包。bcrypt可以用来加密注册用户的密码,避免在数据库中存储明文密码。在https://www.npmjs.com/上可以查看bcrypt包的用法介绍。

> npm install bcrypt

编辑users.js引入并使用User数据模型:

// @login & registtrationconst express = require("express");const router = express.Router();const bcrypt = require("bcrypt");const User = require("../../models/User.js");router.get("/test", (req,res) => {    res.json({msg:"Login succeeded!"})})router.post("/register", (req, res) => {    //console.log(req.body);    // check if email already exists    User.findOne({ email: req.body.email })        .then((user) => {            if (user) {                return res.status(400).json({ email: "邮箱已被注册!" })            } else {                const newUser = new User({                    name: req.body.name,                    email: req.body.email,                    password: req.body.password                })                // encrypt newUser password                bcrypt.genSalt(10, function (err, salt) {                    bcrypt.hash(newUser.password, salt, (err, hash) => {                        if (err) throw err;                        newUser.password = hash;                        newUser.save()                            .then(user => res.json(user))                            .catch(err => console.log(err));                    });                });            }        })})module.exports = router;

在Postman中的Workspace中测试POST http://localhost:5000/api/users/register。Body选择x-www-form-urlencoded,在KEY和VALUE中填入测试内容:

email     godfrey@eldenring.comname      godfreypassword  123456

查看测试输出

{    "name": "godfrey",    "email": "godfrey@eldenring.com",    "password": "$2b$10$hoGzFeIdZyCwEotsYhxEheoGNOCE4QnYYh/WkKoGkuPT0xZI9H10C",    "_id": "62a4482c00990937d819ea6d",    "date": "2022-06-11T07:45:48.437Z",    "__v": 0}

打开mongodb,在DATABASES下的node_app中查看,会发现多出了一个users的Collection,其中刚好存储了上面我们刚通过POST请求插入的一条数据。

使用gravatar处理头像

在https://www.npmjs.com/package/gravatar中查看gravatar的使用方法。

安装gravatar

> npm i gravatar

编辑users.js增加注册头像(avatar)处理:

// @login & registtrationconst express = require("express");const router = express.Router();const bcrypt = require("bcrypt");const gravatar = require("gravatar");const User = require("../../models/User.js");router.get("/test", (req,res) => {    res.json({msg:"Login succeeded!"})})router.post("/register", (req, res) => {    //console.log(req.body);    // check if email already exists    User.findOne({ email: req.body.email })        .then((user) => {            if (user) {                return res.status(400).json({ email: "Email already registered!" })            } else {                const avatar = gravatar.url(req.body.email, { s: '200', r: 'pg', d: 'mm' });                const newUser = new User({                    name: req.body.name,                    email: req.body.email,                    avatar,                    password: req.body.password                })                // encrypt newUser password                bcrypt.genSalt(10, function (err, salt) {                    bcrypt.hash(newUser.password, salt, (err, hash) => {                        if (err) throw err;                        newUser.password = hash;                        newUser.save()                            .then(user => res.json(user))                            .catch(err => console.log(err));                    });                });            }        })})module.exports = router;

在Postman中的Workspace中测试POST http://localhost:5000/api/users/register,Body选择x-www-form-urlencoded。

在KEY和VALUE中填入测试内容:

email     godfrey@eldenring.comname      godfreypassword  123456

测试会返回报错

{    "email": "Email already registered!"}

在KEY和VALUE中填入测试内容:

email      mohg@eldenring.comname       mohgpassword   123456

测试返回

{    "name": "mohg",    "email": "mohg@eldenring.com",    "password": "$2b$10$uSV2tmA5jH6veLTz1Lt5g.iD5QKtbJFXwGsJilDMxIqw7dZefpDz.",    "avatar": "//www.gravatar.com/avatar/c5515cb5392d5e8a91b6e34a11120ff1?s=200&r=pg&d=mm",    "_id": "62a44f12d2c5293f0b8e9c2b",    "date": "2022-06-11T08:15:14.410Z",    "__v": 0}

在浏览器中打开

感谢各位的阅读,以上就是“node.js+postman+mongodb如何搭建测试注册接口”的内容了,经过本文的学习后,相信大家对node.js+postman+mongodb如何搭建测试注册接口这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是编程网,小编将为大家推送更多相关知识点的文章,欢迎关注!

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     807人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     351人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     314人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     433人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     221人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯