rails常用验证方法

validates_presence_of       :login,  :message => "用户名不能为空!"
validates_length_of           :login, :minimum => 4,   :message => "用户名长度须为4到20位字母或数字!"   validates_uniqueness_of   :login,:case_sensitive => false, :message => "该用户名已存在!"
  
validates_presence_of     :password,  :message =>"密码不能为空!"   
validates_length_of         :password,   :minimum => 6,:message=>"密码长度须为6到20位字母或数字! "      
validates_presence_of     :password_confirmation,  :message =>"请再输入一次密码!"  
validates_confirmation_of :password,  :message => "两次密码不一致!"
  
 validates_format_of  :email, :message => "邮箱格式不正确!", :with => /\A([^@\s]+)@((?:[-a-z0-9]+\.)+[a-z]{2,})\Z/i  

 

这里用到了5个主要的验证语法,下面分别介绍:

1、validates_presence_of —— 确认属性值不为nil也不为空。

用法: validates_length_of attr..., [ 选项... ]

选项:

:message =>  缺省是 "is can't be blank."
:on =>:save, :create, 或 :update

 

2、validates_length_of   —— 确认属性值的长度。遵循一些约束: 至少要给出一个长度(如最小长度:minimum,最大长度:maximum,或一个区间:in or :within,但是这三者只能选其一,长度不能负数),而不能只有单个:message选项,这个确认器允许为不同的确认失败分离消息,只要:message还可以使用。

用法: validates_length_of attr..., [ 选项... ]

例子:

validates_length_of :name, :maximum => 50   #这个时候可以自定义:message
validates_length_of :password, :in => 6..20  #这个时候采用默认的:message,忽略自定义内容
validates_length_of :address, :minimum => 10, :message => "seems too short"

 

选项:
:in (或 :within) =>值的长度必须在一个范围内。
:is => integer, 值必须是整数的字符长度。
:minimum =>是一个integer, 值不能小于此整数。
:maximum=> 是一个integer ,值不能大于此整数。
:message =>是一个 text ,消息可以包含一个将被maximun,minimum,或确定长度代替的%d序列。
:on=> :save, :create, 或 :update
:too_long => 是一个text ,使用:maximum时的:message同义词。
:too_short =>是一个 text,使用:minimum时的:message同义词。
:wrong_length =>是一个 text,使用:is 时的:message同义词。

 

 

3、validates_uniqueness_of —— 确认属性是唯一的。对于每个属性,确认数据库内的其它行当前没有与给定列同样的值。
用法: validates_uniqueness_of  attr... [ 选项... ]

选项:
:message =>  缺省是 "has already been taken."
:on =>:save, :create, 或 :update

:scope => attr Limits the check to rows having the same value in the column as the row being checked.

 

4、validates_confirmation_of —— 确认字段和它的值有同样内容。很多表单要求用户输入同一信息两次(如确认密码)如果你使用命名约定,即第二字段的名字附有_confirmation,你可以使用validates_confirmation_of ()来检查两个字段是否有同样的值。

用法:validates_confirmation_of attr... [ 选项... ]

选项:
:message => 缺省是"doesn't match confirmation."
:on  =>:save, :create, 或 :update

 

5、validates_format_of ——  在一个模式上确认属性。通过与正则表达式匹配它的值来确认每个字段。

用法:validates_format_of attr..., :with => regexp  [ 选项... ]

选项:
:message => 缺省是"is invalid."
:on  =>:save, :create, 或 :update

 

此外还有一些验证如下:

 

6、validates_acceptance_of —— 确认checkbox是否被标记。许多表单有checkbox,用户必须选择以便接受一些条款或条件。这个确认简单地检验这个box已经确认被标记,这个属性值是个字符串。属性本身并不被保存在数据库内(如果你希望明确地记录确认的话,没有什么东西会阻止你这样做)。

用法: validates_acceptance_of attr... [ 选项... ]
例子:

validates_acceptance_of :terms, :message => "Please accept the terms to proceed"


选项:

:message => 缺省是"must be accepted."
:on  =>:save, :create, 或 :update

7、validates_associated —— 在关联的对象上完成确认。在给定的属性上完成确认,它被假设为是"活动记录模型"。对每个与属性关联的确认失败的话,一个单独的消息将被添加到那个属性的错误列表中(也就是说,个别的细节原因而出现的失败,将不会写到"模型"的错误列表中)。小心不要包含一个validates_associated()调用在彼此引用的"模型"中:第一个将会试图确认第二个,它依次将确认第一个等等,直接你堆栈溢出。

用法: validates_associated name... [ 选项... ]

例子:

class Order < ActiveRecord::Base
  has_many :line_items
  belongs_to :user
  validates_associated :line_items, :message => "are messed up"
  validates_associated :user
end


选项:

:message => 缺省是"is invalid."
:on  =>:save, :create, 或 :update

 

8、validates_each —— 使用一个块来确认一或多个属性。为每个属性调用块(如果:allow_nil为true,则跳过是nil的属性)。传递属性的名字,属性的值到被确认的"模型"内。如下面例子显示的,如果一个确认失败,块应该被添加给"模型"的错误列表

用法: validates_each attr... [ 选项... ] { |model, attr, value| ... }

例子:

class User < ActiveRecord::Base
  validates_each :name, :email do |model, attr, value|
    if value =~ /groucho|harpo|chico/i

      model.errors.add(attr, "You can't be serious, #{value}")
    end
  end
end

选项:

:allow_nil => boolean值, 如果 :allow_nil 为 true,带有值nil的属性将不被传递给块而是被跳过。

:on  =>:save, :create, 或 :update

 

9、validates_exclusion_of —— 确认属性不在一组值中。确认属性没有出现在枚举中(任何对象都支持include?()断言)。
用法:validates_exclusion_of attr..., :in => enum [ 选项... ]

例子:

class User < ActiveRecord::Base
  validates_exclusion_of :genre,:in => %w{ polka twostep foxtrot },

                         :message => "no wild music allowed"
  validates_exclusion_of :age, :in => 13..19, :message => "cannot be a teenager"
end


选项:
:allow_nil => 如果属性为nil,并且:allow_nil选项为true。则枚举不被检查。
:in (或 :within) => 一个可枚举对象。
:message => 缺省是"is invalid."
:on  =>:save, :create, 或 :update

 

10、validates_inclusion_of —— 确认属性是否属于一个值集。确认每个属性的值是否出现在枚举中(任何对象都支持include?()断言)。
用法:validates_inclusion_of attr..., :in => enum [ 选项... ]

例子:

class User < ActiveRecord::Base
  validates_inclusion_of :gender,:in => %w{ male female },

                         :message => "should be 'male' or 'female'"
  validates_inclusion_of :age,:in => 0..130, :message => "should be between 0 and 130"
end


选项:
:allow_nil => 如果属性为nil,并且:allow_nil选项为true。则枚举不被检查。
:in (或 :within) => 一个可枚举对象。
:message => 缺省是 "is not included in the list."
:on  =>:save, :create, 或 :update

 

 

11、validates_numericality_of —— 确认那个属性是有效的数字。确认每个属性是个有效数字。在:only_integer选项中,属性必须由可选的符号后跟随一个或多个数字。在选项中(或者如果选项不是true),可由Ruby Float()方法允许的任何浮点数都被接受。

用法:validates_numericality_of attr... [ 选项... ]
例子:

class User < ActiveRecord::Base
  validates_numericality_of :height_in_meters
  validates_numericality_of :age, :only_integer => true
end


选项:
:message => 缺省是 "is not a number."
:on=> :save, :create, 或 :update
:only_integer =>如果为 true,则属性必须是包含一个可选的符号后跟随数字的字符串。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
SystemVerilog的听课学习笔记,包括讲义截取、知识点记录、注意事项等细节的标注。 目录如下: 第一章 SV环境构建常识 1 1.1 数据类型 1 四、二值逻辑 4 定宽数组 9 foreach 13 动态数组 16 队列 19 关联数组 21 枚举类型 23 字符串 25 1.2 过程块和方法 27 initial和always 30 function逻辑电路 33 task时序电路 35 动态 静态变量 39 1.3 设计例化和连接 45 第二章 验证方法 393 动态仿真 395 静态检查 397 虚拟模型 403 硬件加速 405 效能验证 408 性能验证 410 第三章 SV组件实现 99 3.1 接口 100 什么是interface 101 接口的优势 108 3.2 采样和数据驱动 112 竞争问题 113 接口中的时序块clocking 123 利于clocking的驱动 133 3.3 测试的开始和结束 136 仿真开始 139 program隐式结束 143 program显式结束 145 软件域program 147 3.4 调试方法 150 第四章 验证的计划 166 4.1 计划概述 166 4.2 计划的内容 173 4.3 计划的实现 185 4.4 计划的进程评估 194 第五章 验证的管理 277 6.1 验证的周期检查 277 6.2 管理三要素 291 6.3 验证的收敛 303 6.4 问题追踪 314 6.5 团队建设 321 6.6 验证的专业化 330 第六章 验证平台的结构 48 2.1 测试平台 49 2.2 硬件设计描述 55 MCDF接口描述 58 MCDF接口时序 62 MCDF寄存器描述 65 2.3 激励发生器 67 channel initiator 72 register initiator 73 2.4 监测器 74 2.5 比较器 81 2.6 验证结构 95 第七章 激励发生封装:类 209 5.1 概述 209 5.2 类的成员 233 5.3 类的继承 245 三种类型权限 protected/local/public 247 this super 253 成员覆盖 257 5.4 句柄的使用 263 5.5 包的使用 269 第八章 激励发生的随机化 340 7.1 随机约束和分布 340 权重分布 353 条件约束 355 7.2 约束块控制 358 7.3 随机函数 366 7.4 数组约束 373 7.5 随机控制 388 第九章 线程与通信 432 9.1 线程的使用 432 9.2 线程的控制 441 三个fork...join 443 等待衍生线程 451 停止线程disable 451 9.3 线程的通信 458 第十章 进程评估:覆盖率 495 10.1 覆盖率类型 495 10.2 功能覆盖策略 510 10.3 覆盖组 516 10.4 数据采样 524 10.5 覆盖选项 544 10.6 数据分析 550 第十一章 SV语言核心进阶 552 11.1 类型转换 552 11.2 虚方法 564 11.3 对象拷贝 575 11.4 回调函数 584 11.5 参数化的类 590 第十二章 UVM简介 392 8.2 UVM简介 414 8.3 UVM组件 420 8.4 UVM环境 425

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值