资讯专栏INFORMATION COLUMN

koa2系列教程:koa2实现登录注册功能

baiy / 1631人阅读

摘要:系列教程,持续更新系列教程应用初见系列教程处理静态文件系列教程使用模板引擎系列教程路由控制中间件系列教程综合搭建登录注册页面系列教程实现登录注册功能这个主要结合前几天的内容,做个实际案例的效果版本项目结构前几天,我们把注册和登录的页面实现了

koa2系列教程,持续更新

koa2系列教程:koa2应用初见

koa2系列教程:koa2处理静态文件

koa2系列教程:koa2使用模板引擎

koa2系列教程:koa2路由控制中间件

koa2系列教程:综合koa2搭建登录注册页面

koa2系列教程:koa2实现登录注册功能

这个主要结合前几天的内容,做个实际案例的效果

版本:

项目结构:

前几天,我们把注册和登录的页面demo实现了,今天我们主要实现这么几个内容

注册新用户

判断该邮箱是否注册过

登录判断是否注册过

登录时的密码的正确

本文代码地址:https://github.com/xiaqijian/...

明天,我们将利用session实现登录状态判断

今天的这篇是在之前的代码基础上添加的,我们就晒主要的代码

1.编辑user.js
// db/user.js
const mongoose = require("./db")
const Schema = mongoose.Schema;

const ceshiSchema = new Schema({
  email: String,
  name: String,
  password: String
});

const MyModel = mongoose.model("User", ceshiSchema);


class Userdb {
  constructor () {

  }
// 查询
  query (obj = {}) {
     return new Promise((resolve, reject) => {
       MyModel.find(obj, (err, res) => {
         if(err) {
           reject(err)
         }
         resolve(res)
       })
     })
  }
queryEmail (em) {
   return new Promise((resolve, reject) => {
     MyModel.find({email: em}, (err, res) => {
       if(err) {
         reject(err)
       }
       const len = res.length
       if(len >= 1){
         // 存在
         resolve(res)
       }else {
         // 不存在
         resolve(null)
       }
     })
   })
}
// 保存
  save (obj) {
     const m = new MyModel(obj)
     return new Promise((resolve, reject)=> {
       m.save((err, res) => {
         if (err) {
           reject(err)
         }
         resolve(res)
         console.log(res)
       })
     })
     
  }
}
module.exports = new Userdb()

上面主要查询用户,和保存用户

2.编辑 登录注册路由
// router/index.js

const Router = require("koa-router")


// 
const User = require("../db/user")
const home = new Router()

home.get("/", async (ctx) => {
    let title = "首页"
    await ctx.render("index", {
        title
    })
})


// 子路由2
const page = new Router()

page.get("/404", async (ctx) => {
    let title = "404"
    await ctx.render("err", {
        title
    })
})


const login = new Router()

login.get("/", async (ctx) => {
    let title = "登录"
    await ctx.render("login", {
        title
    })
}).post("/", async (ctx) => {
    const data = ctx.request.body
    let queryres = await User.queryEmail(data.email)
    console.log(queryres)
    if (queryres) {
        if(queryres[0].password === data.password) {
            ctx.body = {
                "code": 1,
                "data": queryres[0],
                "mesg": "登录成功"
            }
        }else {
            ctx.body = {
                "code": 0,
                "data": {},
                "mesg": "密码错误"
            }
        }
        
    }else {
        ctx.body = {
            "code": 0,
            "data": {},
            "mesg": "没有该用户,去注册吧"
        }
    }
})

const register = new Router()

register.get("/", async (ctx) => {
    let title = "注册"
    await ctx.render("register", {
        title
    })
}).post("/", async (ctx) => {
    const data = ctx.request.body
    let queryres = await User.queryEmail(data.email)
    if (queryres) {
        ctx.body = {
            "code": 0,
            "data": {},
            "mesg": "该邮箱已经存在哦"
        }
    }else {
        await User.save(data)
        ctx.body = {
            "code": 1,
            "data": {},
            "mesg": "保存成功"
        }
    }
   
})

// 装载所有子路由
let router = new Router()
router.use("/", home.routes(), home.allowedMethods())
router.use("/page", page.routes(), page.allowedMethods())
router.use("/login", login.routes(), login.allowedMethods())
router.use("/register", register.routes(), register.allowedMethods())


module.exports = router
3.编辑index.js
const Koa = require("koa")
const views = require("koa-views")
const statics =  require("koa-static")
const bodyparser = require("koa-bodyparser")
const path = require("path")
const router =  require("./router")
const app = new Koa()

const staticPath = "./static"

app.use(statics(
  path.join(__dirname, staticPath)
))
app.use(bodyparser())

// 加载模板引擎
app.use(views(path.join(__dirname, "./views"), {
    extension: "ejs"
  }))

// 加载路由中间件
app.use(router.routes()).use(router.allowedMethods())

app.listen(3000, () => {
    console.log("localhost:3000")
})

这个和之前的内容增加了koa-bodyparser对post数据的解析,利用ctx.request.body获取

4.启动服务
node index.js

打开浏览器localhost:3000

尝试去登录注册一下,打开控制台,就可以看得到相关后台返回的数据

本文结束,下次文章利用session对登录状态的判断

本文代码地址:https://github.com/xiaqijian/...

本文首发于:node前端

不妨关注一下

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/99678.html

相关文章

  • koa2系列教程:综合koa2搭建登录注册页面

    摘要:系列教程,持续更新系列教程应用初见系列教程处理静态文件系列教程使用模板引擎系列教程路由控制中间件系列教程综合搭建登录注册页面系列教程实现登录注册功能本文源码地址这篇是将前几天的内容做个综合,运用静态文件处理,路由,模板引擎我的版本项目结构是 koa2系列教程,持续更新 koa2系列教程:koa2应用初见 koa2系列教程:koa2处理静态文件 koa2系列教程:koa2使用模板引擎 ...

    li21 评论0 收藏0
  • koa2系列教程koa2应用初见

    摘要:系列教程,持续更新系列教程应用初见系列教程处理静态文件系列教程使用模板引擎系列教程路由控制中间件系列教程综合搭建登录注册页面系列教程实现登录注册功能这篇教程主要介绍构建服务器,简单引用本教程的版本要格外注意版本号案例简单利用搭建服务器文件夹 koa2系列教程,持续更新 koa2系列教程:koa2应用初见 koa2系列教程:koa2处理静态文件 koa2系列教程:koa2使用模板引擎 ...

    import. 评论0 收藏0
  • koa2系列教程koa2处理静态文件

    摘要:系列教程,持续更新系列教程应用初见系列教程处理静态文件系列教程使用模板引擎系列教程路由控制中间件系列教程综合搭建登录注册页面系列教程实现登录注册功能这篇主要介绍处理静态文件的中间件用到的版本项目的结构大家可以往文件夹里面添加点东西编辑启动 koa2系列教程,持续更新 koa2系列教程:koa2应用初见 koa2系列教程:koa2处理静态文件 koa2系列教程:koa2使用模板引擎 k...

    madthumb 评论0 收藏0
  • koa2系列教程koa2使用模板引擎

    摘要:系列教程,持续更新系列教程应用初见系列教程处理静态文件系列教程使用模板引擎系列教程路由控制中间件系列教程综合搭建登录注册页面系列教程实现登录注册功能这篇教大家如何使用模板引擎这里我们使用模板引擎做个例子,你们自己选择自己熟练的模板引擎使用的 koa2系列教程,持续更新 koa2系列教程:koa2应用初见 koa2系列教程:koa2处理静态文件 koa2系列教程:koa2使用模板引擎 ...

    ZoomQuiet 评论0 收藏0
  • koa2系列教程koa2路由控制中间件

    摘要:系列教程,持续更新系列教程应用初见系列教程处理静态文件系列教程使用模板引擎系列教程路由控制中间件系列教程综合搭建登录注册页面这篇我们来使用一个控制一下路由本篇的版本注意版本哦目录结构编辑子路由子路由装载所有子路由加载路由中间件启动服务, koa2系列教程,持续更新 koa2系列教程:koa2应用初见 koa2系列教程:koa2处理静态文件 koa2系列教程:koa2使用模板引擎 ko...

    lily_wang 评论0 收藏0

发表评论

0条评论

baiy

|高级讲师

TA的文章

阅读更多
最新活动
阅读需要支付1元查看
<