为了账号安全,请及时绑定邮箱和手机立即绑定

【金秋打卡】第5天 Node.js+Koa2+MySQL打造前后端分离精品项目《旧岛》

课程章节: 【构建用户身份系统】通用用户系统与小程序用户系统

课程讲师: 7七月

课程内容:

Sequelize个性化配置与数据维护策略

在 db.js 中

sequelize.sync() // 如果不加的话, sequelize库是不会把这些模型全部创建到数据库里

sequelize.sync({force: true}) 为 true 话 新增了参数会删除原有的表,新增有参数的表   上正式千万不要设置成true

// 如果不要update_time, create_time, delete_time 需要在   非常有用不建议删除
define: {
	timestamps: false,  // 还是需要改成true
	paranoid: true, // 会生成一个 delete_time 的时间戳
	createdAt: 'created_at',
	updateAt: 'updated_at',
	deletedAt: 'deleted_at',
	underscored: true, // 通过这个可以把驼峰转换成下划线
}

在 models/user.js中
User.init 参数接收两个对象, 最后一个对象接收

tableName: 'user', // 指定表名

LinValidator综合应用

在 创建 api/v1/user.js 编写api
用户注册

const Router = require('koa-router')
const router = new Router({prefix: '/v1/user'})
const { RegisterValidator } = require(validator)
// 注册 新增数据 put get delete
router.get('/register', async (ctx) => {
	// 接收参数
	// email password1 password2 phone
	const v = new RegisterValidator().validate(ctx) // 传入
})
module.exports = router

在 validator.js
注册 效验

class RegisterValidator extends LinValidator {
	constructor() {
		super()
		this.email = [
			new Rule('isEmail', '不符合Email规范')
        ]
        this.password1 = [
			new Rule('isLength', '密码至少6个字符, 最多32个字符', { min: 6, max: 32 }),
			new Rule('matches', '密码不符合规范', '^(?![0-9]+$)(?![a-zA-Z]+$)[0-9A-Za-z]')
        ]
        this.password2 = this.password1 // 效验规则相同
        this.nickname = [
            new Rule('isLength', '昵称不符合长度规范', {
            min: 6,
            max: 32
            })
    ]
    }
    validatePassword(vals) {
    const psw1 = vals.body.password1
    const psw2 = vals.body.password2
    if (psw1 !== psw2) {
      throw new Error('两个密码必须相同')
    }
  }
}

导出这个类
module.exports = {
	RegisterValidator
}

出现报错
middlewares/exception.js

    // 开发环境
    const isHttpException = error instanceof HttpException
    const isDev = global.config.environment === 'dev'
    // 如果是开发环境 不是HttpException这个类处理的 就直接报错
    if (isDev && !isHttpException) {
      throw error
    }
        // 生产环境
    // 已知错误
    if (isHttpException) {
      ctx.body = {
        msg: error.msg,
        errorCode: error.errorCode,
        request: `${ctx.method} ${ctx.path}`
      }
      ctx.status = error.code
    } else {
      // 未知异常
      ctx.body = {
        msg: 'we made a mistake',
        errorCode: 999,
        request: `${ctx.method} ${ctx.path}`
      }
      ctx.status = 500
    }

课程收获

对 sequelize 的参数有一定了解

点击查看更多内容
TA 点赞

若觉得本文不错,就分享一下吧!

评论

作者其他优质文章

正在加载中
  • 推荐
  • 评论
  • 收藏
  • 共同学习,写下你的评论
感谢您的支持,我会继续努力的~
扫码打赏,你说多少就多少
赞赏金额会直接到老师账户
支付方式
打开微信扫一扫,即可进行扫码打赏哦
今天注册有机会得

100积分直接送

付费专栏免费学

大额优惠券免费领

立即参与 放弃机会
意见反馈 帮助中心 APP下载
官方微信

举报

0/150
提交
取消