zoukankan      html  css  js  c++  java
  • koa 项目实战(十一)验证登录和注册的 input

    1.验证注册参数

    根目录/validation/register.js

    const Validator = require('validator');
    const isEmpty = require('./is-empty');
    
    module.exports = function validateRegisterInput(data) {
      let errors = {};
    
      data.name = !isEmpty(data.name) ? data.name : '';
      data.email = !isEmpty(data.email) ? data.email : '';
      data.password = !isEmpty(data.password) ? data.password : '';
      data.password2 = !isEmpty(data.password2) ? data.password2 : '';
    
      if (!Validator.isLength(data.name, { min: 2, max: 30 })) {
        errors.name = '名字的长度不能小于2位且不能超过30位';
      }
    
      if (Validator.isEmpty(data.name)) {
        errors.name = '名字不能为空';
      }
    
      if (!Validator.isEmail(data.email)) {
        errors.email = '邮箱不合法';
      }
    
      if (Validator.isEmpty(data.email)) {
        errors.email = '邮箱不能为空';
      }
    
      if (Validator.isEmpty(data.password)) {
        errors.password = 'password不能为空';
      }
    
      if (!Validator.isLength(data.password, { min: 6, max: 30 })) {
        errors.password = 'password的长度不能小于6位且不能超过30位';
      }
    
      if (Validator.isEmpty(data.password2)) {
        errors.password2 = 'password2不能为空';
      }
    
      if (!Validator.equals(data.password, data.password2)) {
        errors.password2 = '两次密码不一致';
      }
    
      return {
        errors,
        isValid: isEmpty(errors)
      }
    }

    2.验证登录参数

    根目录/validation/login.js

    const Validator = require('validator');
    const isEmpty = require('./is-empty');
    
    module.exports = function validateLoginInput(data) {
      let errors = {};
    
      data.email = !isEmpty(data.email) ? data.email : '';
      data.password = !isEmpty(data.password) ? data.password : '';
    
      if (!Validator.isEmail(data.email)) {
        errors.email = '邮箱不合法';
      }
    
      if (Validator.isEmpty(data.email)) {
        errors.email = '邮箱不能为空';
      }
    
      if (Validator.isEmpty(data.password)) {
        errors.password = 'password不能为空';
      }
    
      if (!Validator.isLength(data.password, { min: 6, max: 30 })) {
        errors.password = 'password的长度不能小于6位且不能超过30位';
      }
    
      return {
        errors,
        isValid: isEmpty(errors)
      }
    }

    3.引用

    根目录/routes/api/users.js

    // 引入 input 验证密码
    const validateRegisterInput = require('../../validation/register');
    const validateLoginInput = require('../../validation/login');
    ...
    
    // 注册接口
    const { errors, isValid } = validateRegisterInput(ctx.request.body);
    
    // 判断是否验证通过
    if (!isValid) {
      ctx.status = 400;
      ctx.body = errors;
      return;
    }
    
    // 登录接口
    const { errors, isValid } = validateLoginInput(ctx.request.body);
    
    // 判断是否验证通过
    if (!isValid) {
      ctx.status = 400;
      ctx.body = errors;
      return;
    }

    .

  • 相关阅读:
    Visual Studio 中的 .NET Framework 类库
    泛型
    泛型
    事件
    基于事件的异步模式
    使用委托进行异步编程
    使用 IAsyncResult 调用异步方法
    异步编程设计模式
    演练:使用VS2010 C# 创作简单的多线程组件
    [转][MEF插件式开发] 一个简单的例子
  • 原文地址:https://www.cnblogs.com/crazycode2/p/11080199.html
Copyright © 2011-2022 走看看