Javascript Node.js的验证库

Javascript Node.js的验证库,javascript,validation,node.js,Javascript,Validation,Node.js,node.js是否有一个好的验证框架,用于验证以下变量: 如果是字符串、日期、数字等类型 最大和最小长度 电子邮件、电话 等等 不是在变量级别,而是在函数参数级别: 日期当前需要作为“对象”类型传递。这肯定是我已经忘记的事情,我会把它放在待办事项清单上 不支持特定的最大和最小长度,并且可能不会实现(但谁知道呢)。电子邮件、电话以及所有可由regex检查的内容。请参阅github页面上的示例,其中包括一个(简单的)regex示例。我认为这就是模块要做的事情。注意,它被标记为“正在开发中”(标记

node.js是否有一个好的验证框架,用于验证以下变量:

  • 如果是字符串、日期、数字等类型
  • 最大和最小长度
  • 电子邮件、电话
  • 等等

    • 不是在变量级别,而是在函数参数级别:

      日期当前需要作为“对象”类型传递。这肯定是我已经忘记的事情,我会把它放在待办事项清单上


      不支持特定的最大和最小长度,并且可能不会实现(但谁知道呢)。电子邮件、电话以及所有可由regex检查的内容。请参阅github页面上的示例,其中包括一个(简单的)regex示例。

      我认为这就是模块要做的事情。注意,它被标记为“正在开发中”(标记为v0.1a)。我自己没有试过,但从自述文件中的示例来看,它看起来相当不错。

      我最近发现了

      示例

      var check = require('validator').check,
          sanitize = require('validator').sanitize
      
      //Validate
      check('test@email.com').len(6, 64).isEmail();       //Methods are chainable
      check('abc').isInt();                               //Throws 'Invalid integer'
      check('abc', 'Please enter a number').isInt();      //Throws 'Please enter a number'
      check('abcdefghijklmnopzrtsuvqxyz').is(/^[a-z]+$/);
      
      //Sanitize / Filter
      var int = sanitize('0123').toInt();                  //123
      var bool = sanitize('true').toBoolean();             //true
      var str = sanitize(' \s\t\r hello \n').trim();      //'hello'
      var str = sanitize('aaaaaaaaab').ltrim('a');        //'b'
      var str = sanitize(large_input_str).xss();
      var str = sanitize('&lt;a&gt;').entityDecode();     //'<a>'
      
      var check=require('validator')。检查,
      清理=需要(“验证器”)。清理
      //证实
      支票('test@email.comlen(6,64).isEmail()//方法是可链接的
      检查('abc')。isInt()//抛出“无效整数”
      勾选('abc','请输入一个数字')。isInt()//抛出“请输入一个数字”
      检查('abcdefghijklmnopzrtsuvqxyz')。是(/^[a-z]+$/);
      //消毒/过滤
      var int=sanitize('0123').toInt()//123
      var bool=sanitize('true').toBoolean()//真的
      var str=sanitize('\s\t\r hello\n').trim();/'你好’
      var str=sanitize('aaaaaab').ltrim('a');/'b'
      var str=sanitize(大输入);
      var str=sanitize('a')。entityDecode();/“”
      
      是字符串验证、筛选和清理方法的库

      因此,如果您想更好地支持数字和数组,可以尝试。以下是一些例子:

      var expect = require('chai').expect;
      try {
          expect([1, 2, 3]).to.have.length.below(4);
          expect(5).to.be.within(3,6);
          expect('test').to.have.length(4);
      } catch (e) {
          // should not occur
      }
      

      我想要RubyonRails和cakephp风格的验证。我知道我会反复使用它,所以我制作了这个快速npm模块:

      它在语义上与jasmine相似,可以在客户端或服务器端使用。这意味着它支持commonjs和amd以及通过JSON传递的验证规则

      它经过了很好的单元测试,没有生产依赖关系,并且范围仅限于验证。我们现在似乎有一个小社区。欢迎提出想法、反馈和请求

      目前图书馆的职能:

      iz.alphaNumeric(*);               // Is number or string(contains only numbers or strings)
      iz.between(number, start, end);   // Number is start or greater but less than or equal to end, all params numeric
      iz.blank(*);                      // Empty string, undefined or null
      iz.boolean(*);                    // true, false, 0, 1
      iz.cc(*);                         // Luhn checksum approved value
      iz.date(*);                       // Is a data obj or is a string that is easily converted to a date
      iz.decimal(*);                    // Contains 1 decimal point and potentially can have a - at the beginning
      iz.email(*);                      // Seems like a valid email address
      iz.extension(ob1, ob2);           // If obj2's methods are all found in obj1
      iz.fileExtension(arr, value);     // Checks if the extension of value is in arr. An obj can be provide, but must have indexOf defined.
      iz.fileExtensionAudio(value);     // Check against mp3, ogg, wav, aac
      iz.fileExtensionImage(value);     // Check against png, jpg, jpeg, gif, bmp, svg, gif
      iz.inArray(arr, value);           // If * is in the array
      iz.int(*, bool (optional));       // Is an int. If the 2nd variable is true (false by default) a decimal is allowed
      iz.ip(str);                       // str resembles an IPV4 or IPV6 address
      iz.minLen(val, min);              // val (str or arr) is greater than min
      iz.maxLen(val, max);              // val (str or arr) is shorter than max
      iz.multiple(num, mult);           // Number is multiple of another number
      iz.number(*);                     // Is either an int or decimal
      iz.ofType(obj, typeName);         // If it is a named object, and the name matches the string
      iz.phone(str, canHaveExtension?); // Is an american phone number. Any punctuations are allowed.
      iz.postal(*);                     // Is a postal code or zip code
      iz.ssn(*);                        // Is a social security number
      
      我建议您缺少文档,但是查看文档很容易理解

      Valida的特点是:

      • 消毒
      • 同步和异步验证
      • 团体
      • 可扩展

      我将完成Javascript验证库(节点和浏览器)的编写,我将在接下来的几天内编写文档,但代码几乎准备就绪:


      如果您对此有任何问题/建议,请告诉我:)

      是,但节点验证器侧重于字符串验证。因此,检查诸如“is of type Date?”之类的变量的类型是非常糟糕的。我真的很喜欢他们关于验证应该如何工作的想法,我认为这是一个方便的想法,但是我想有一种方法来进行更严格的验证。我刚刚发布了这个新的验证框架:我找不到如何对可选参数使用validator?节点验证器是否提供了这一点。我检查了所有的节点,发现它们都没有表现力,我写了自己的“无意冒犯”,但to.have,to.be对我来说似乎没用。我是在写诗还是在写程序
      如果(字符串)I.want.to.validate.is.短于(123)==false{console.log('string's too long');}
      存在超长且无用的方法调用,因为Chai是为编写单元测试而设计的。@SavasVedova,您正在编写这两个方法。因为问题已结束,我正在评论我的答案,来自hapi的joi.js是一个相当广泛的javascript模型框架。它有你想要的一切,还有更多。优秀的文档和在生产中使用它的优秀用户我鼓励您检查提供基于模式的验证和错误处理的框架。这是Node.js的某种ActiveRecord。