rails 常用的验证方法 validates (转)

Agile Web Development with Rails

17.4 validation

validate              在save的时候激活
validate_on_create      create
validate_on_update      update

通过这三个方法可以添加
validates_XXX_xxx没有的功能
错误信息写进err
#:name 是验证的属性名
def validate
    unless name && name =~ /^\w+$/
        errors.add(:name, "is missing or invalid" )
    end
end

validates_方法有两个选项 
:on       指明激活的时间 save,update,create
:message  出错时显示的消息

validate_acceptiance_of 验证复选框是否勾选
    validates_acceptance_of :terms,
        :message => "Please accept the terms to proceed"

validate_associated  数据库关联

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

validates_confirmation_of  验证变量值是否一直
    在使用的时候要注意变量名,用于验证的变量名要为 XXX_confirmation
        如要验证 password,相对的变量应为 password_confirmation

validates_each attr... [ options... ] { |model, attr, value| ... } 用block验证
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

validates_exclusion_of attr..., :in => enum [ options... ]
验证排除在外的值,使用枚举
    validates_exclusion_of :age,
        :in => 13..19,
        :message => "cannot be a teenager"
        
validates_inclusion_of attr..., :in => enum [ options... ]
验证在内的值
    validates_inclusion_of :gender,
        :in => %w{ male female },
        :message => "should be ‘male‘ or ‘female‘"
        
validates_format_of attr..., :with => regexp [ options... ]
验证格式,使用正则表达式

validates_length_of
验证长度
    class User < ActiveRecord::Base
        validates_length_of :name, :maximum => 50
        validates_length_of :password, :in => 6..20
        validates_length_of :address, :minimum => 10,
            :message => "seems too short"
    end

validates_numericality_of 验证是否是数值
    :only_integer  是否是整数
    
validates_presence_of 验证是否为空

validates_uniqueness_of 验证是否唯一
    和数据库中已有的记录比较。 scope选项限制范围
    
    class User < ActiveRecord::Base
        validates_uniqueness_of :name, :scope => "group_id"
    end
---------------------------------------------------
17.5 回调
使用回调机制,可以让我们的代码参与进程监控

class User < ActiveRecord::Base
    before_destroy :dont_destroy_dave
    def dont_destroy_dave
        raise "Can‘t destroy dave" if name == ‘dave‘
    end
end

回调的点有很多
如 before_validation
   after_validation
   before_save
   after_save
   after_create
   after_save
   ...
   
见332页,一共有20个回调点
使用回调有两种方式
1是定义和回调点一样名字的方法
class Order < ActiveRecord::Base
# ..
    def before_save
        self.payment_due ||= Time.now + 30.days
    end
end

2.是定义句柄作为方法名,下面的normalize_credit_card_number(有点像filter),可同时使用多个句柄
class Order < ActiveRecord::Base
    before_validation :normalize_credit_card_number
    after_create do |order|
        logger.info "Order #{order.id} created"
    end
protected
    def normalize_credit_card_number
        self.cc_number.gsub!(/-\w/, ‘‘ )
    end
end

回调对象
除了在model中直接使用回调,还可以定义回调对象,这样就可以跨多个model使用
class CreditCardCallbacks
# Normalize the credit card number
    def before_validation(model)
        model.cc_number.gsub!(/-\w/, ‘‘ )
    end
end
下面是回调对象如何在两个不同的类中激活的
class Order < ActiveRecord::Base
    before_validation CreditCardCallbacks.new
# ...
end
class Subscription < ActiveRecord::Base
    before_validation CreditCardCallbacks.new
# ...
end

Observers
回调可能使不相关的model联系在一起,通过observer可以避免这个缺陷
通过observer使用回调的功能
OrderObserver是Order模型的程序钩子,等同于在order模型内直接使用回调
class OrderObserver < ActiveRecord::Observer
    def after_save(an_order)
        an_order.logger.info("Order #{an_order.id} created" )
    end
end
OrderObserver.instance

observer可以用于多个model
class AuditObserver < ActiveRecord::Observer
    observe Order, Payment, Refund
    def after_save(model)
        model.logger.info("#{model.class.name} #{model.id} created" )
    end
end

AuditObserver.instance

时间: 2024-08-10 15:09:05

rails 常用的验证方法 validates (转)的相关文章

java 常用的验证方法帮助类

import java.text.ParseException; import java.util.Collection; import java.util.Map; /** * 常用的验证方法帮助类,提供对字符串,集合,数组,数值的验证 * * */ public class ValidateHelper { /** * 判断一个字符串是否不是一个空字符串 * * @param s 要判断的字符串 * @return 如果不为空返回true,否则返回false */ public static

前端开发之常用验证方法

在日常开发中,经常需要对提交的数据进行验证处理,总结一下常用的验证方法. 1)邮箱验证 function checkEmail(email) { var reg = /^([a-zA-Z0-9_-])[email protected]([a-zA-Z0-9_-])+((\.[a-zA-Z0-9_-]{2,3}){1,2})$/; return reg.test(email); //检测是否匹配 } 2)电话验证 // 判断是否为手机号 function isPoneAvailable(pone)

常用表单数据的验证方法

1.姓名验证 ereg("[a-zA-Z_]",$_POST['username']) 2.日期验证 ereg("[0-9]{4}-[0-9]{2}-[0-9]{2}",$_POST['birthday']) 3.E-mail地址验证 ereg("^[a-zA-Z0-9_.]+@([a-zA-Z0-9_]+.)+[a-zA-Z]{2,3}$",$_POST['email']) 常用表单数据的验证方法

结合Scikit-learn介绍几种常用的特征选择方法

作者:Edwin Jarvis 特征选择(排序)对于数据科学家.机器学习从业者来说非常重要.好的特征选择能够提升模型的性能,更能帮助我们理解数据的特点.底层结构,这对进一步改善模型.算法都有着重要作用. 特征选择主要有两个功能: 减少特征数量.降维,使模型泛化能力更强,减少过拟合 增强对特征和特征值之间的理解 拿到数据集,一个特征选择方法,往往很难同时完成这两个目的.通常情况下,我们经常不管三七二十一,选择一种自己最熟悉或者最方便的特征选择方法(往往目的是降维,而忽略了对特征和数据理解的目的).

Struts2 验证框架 validation.xml 常用的验证规则

Struts2 验证框架 validation.xml 常用的验证规则 validation.xml 的命名规则和放置路径:文件名:<ActionClassName>-validation.xml<ActionClassName>就是要验证的Action类的名字. 要将此文件放于Class文件相同的目录.如果在Action类在struts配置中有多个action实例(action name),那么对应某个action的验证文件名规则如下:文件名:<ActionClassNam

干货:结合Scikit-learn介绍几种常用的特征选择方法

原文  http://dataunion.org/14072.html 主题 特征选择 scikit-learn 作者: Edwin Jarvis 特征选择(排序)对于数据科学家.机器学习从业者来说非常重要.好的特征选择能够提升模型的性能,更能帮助我们理解数据的特点.底层结构,这对进一步改善模型.算法都有着重要作用. 特征选择主要有两个功能: 减少特征数量.降维,使模型泛化能力更强,减少过拟合 增强对特征和特征值之间的理解 拿到数据集,一个特征选择方法,往往很难同时完成这两个目的.通常情况下,我

BP神经网络设计常用的基本方法和实用技术

尽管神经网络的研究和应用已经取得巨大成功,但在网络的开发设计方面至今仍没有一套完善的理论做指导,应用中采取的主要设计方法是,在充分了解待解决问题的基础上将经验与试探相结合,通过多次改进性试验,最终选出一个较好的设计方案.下面是在开发神经网络中常用的基本方法和实用技术. (1)  网络信息容量与训练样本数 多层神经网络的分类能力与网络信息容量相关,如果网络的权值和阈值总数nw表征网络信息容量,研究表明,训练样本数N与给定的训练误差ε之间应满足以下匹配关系: N = nw / ε. 上式表明网络的信

认识黑客常用的入侵方法

认识黑客常用的入侵方法 导读 在Interent中,为了防止黑客入侵自己的计算机,就必须了解黑客入侵目标计算机的常用方法.黑客常用的入侵方法有数据驱动攻击.系统文件非法利用.伪造信息攻击 以及远端操纵等,下面就简单介绍这些入侵方法. 数据驱动攻击 数据驱动攻击是指黑客向目标计算机发送或复制的表面上看来无害的特殊程序被执行时所发起的攻击.该攻击可以让黑客在目标计算机上修改与网络安全有关的文件,从而使黑客在下一次更容易入侵该目标计算机.数据驱动攻击主要包括缓冲区溢出攻击.格式化字符串攻击.输入验证攻

Jquery Easyui框架中常用的验证

对于validatebox空间,验证其输入字符长度的最大值是否超出数据库中设置的字段长度.方法如下: 1 /** 2 * 验证输入字符长度 3 */ 4 $.extend($.fn.validatebox.defaults.rules, { 5 maxLength: { 6 validator: function(value, param){ 7 if(value.length >= param[0]) { 8 // showMsg("输入信息长度不能超过"+ param[0]