`
Readonly
  • 浏览: 150813 次
  • 性别: Icon_minigender_1
  • 来自: 上海
社区版块
存档分类
最新评论

师傅领错门,害了你个人 - ruby/rails新手避免入错门

阅读更多
最近看到一位Ruby On Rails新手写的代码,简直是惨不忍睹,问了一下他竟然是用李刚写的那本<<Ruby on Rails敏捷开发最佳实践>>作为入门材料的,偶真是faint,啥也不多说了,为了让更多的Ruby On Rails的新手避免走弯路,偶觉得很有必要来评论一下这本书,以china pub上下载的第15章样章为例子:
http://www.china-pub.com/39348

这章是讲一个注册用户通过邮件注册激活的例子,偶们来看看所谓的最佳实践实际是如何成为绝佳反面教材:
1. 创建一个用户表
这里使用的是sql,而不是Rails最佳实践推荐的migration

2. 用户表中直接用明码保存用户的密码
请各位作实际开发新手注意:任何一个应用都不应该犯这样愚蠢的错误

3. 标示用户是否激活的字段名叫is_actived
这不符合rails的最佳实践写法,对于boolean类型的数据,应该省略前面的is_,ActiveRecord会自动加个?号,映射成actived?

4. User模型的校验功能用errors.add这样手工的方法
最佳实践是使用Validation DSL,除非ActiveRecord提供的DSL不能满足你的特殊校验需求,否则毫无必要自己手工处理
就算你有很特殊的校验需求,在这段代码里面也应该使用errors.add_to_base,而不是用errors.add_base,跟一个空白的字符串

5. 设置用户的默认激活为false:@user.is_activated = false
Rails的理念是COC和DRY,这种初始默认值的设定应该在创建数据库定义的时候指定,而且默认的boolean都是false,这里的赋值完全是多此一举

让我们先休息和回顾一下,上面提到的5个绝佳反面教材竟然是出现在一个章节中的一个小段:15.4.1基本注册功能,错误之密集真是令人咋舌。
如果你和偶一样,还能忍受下去,恭喜你,你具备了给烂代码作Code Review的基本要求:耐力

偶们来继续往下看:
6. 看看发送邮件的代码
@sent_on = Time.now
@headers = {}


@sent_on指定的是邮件头信息中的Date,默认就是使用当前时间,这里的赋值也是多此一举
@headers指定的是邮件头信息的hash,这里也是也是多此一举
结合之前的问题5,李刚老师您这是用无用代码来充书本厚度么?


7. if user != nil && user.is_activated == false
user.is_activated == false ??? 这叫啥代码阿? 偶的天哪,李刚老师可能是为了保持风格统一,后面果然还有 user.is_activated == true ,这是偶看到搞笑的代码了...

8. pro_activate Action的代码写得及其冗长
综合前面的错误,偶想李刚可能压根不懂一些ruby和rails的惯用法,偶好为人师一下,符合ruby风格的代码应该是这样:
def pro_activate
  user = User.find_by_name_and_active_code(params[:name], params[:active_code])
  if user 
    if user.actived?
      flash[:notice] = "您的账户已经处于激活状态,请勿重复激活!"		
    else
      user.update_attribute(:activated , true)
      flash[:notice] = "恭喜您,您已经成功激活了您的账户!"
    end
  else
    flash[:notice] = "激活失败!"
  end
end

而且在实际开发中,作为最佳实践,最后一个else判断完全是不必要的,大家可以想想什么情况下会出现跑到最后一个else?嗯,只有在恶意构造url攻击的情况下,这样我们完全可以改成:
User.find_by_name_and_active_code_and_active(params[:name], params[:active_code], false)
在之后的pro_login action里面的代码就不多说了,和前面一样,也有user != nil && user.is_activated == false这样搞笑的代码出现。

看完了这个短短5页的样章中有那么多的错误,偶明白了为什么那个新手写的代码是如此的惨不忍睹,虽然俗话说,师傅领进门,修行在个人,但是也要晓得:师傅领错门,害了你个人
最后推荐了另外几本Ruby和Rails的书给他,让他好好改造去了...
分享到:
评论
220 楼 richardyu 2008-11-13  
right now 写道

别打击啦,大家消消火,都是中国人,JE不能太过分啊


貌似做三鹿的也是中国人,是不是你也想劝大家消消火,继续支持国货狂喝三鹿啊?打着国产的牌子明目张胆的推广垃圾产品就是不对。
219 楼 logo 2008-11-13  
right now 写道
别打击啦,大家消消火,都是中国人,JE不能太过分啊



那田江东给JavaEye打骚扰电话过分不过分? 李刚在自己的网站上面一而再,再而三的诬蔑JavaEye网站过分不过分? 这种误人子弟的图书到处软文宣传过分不过分? 你怎么不去劝劝他们呢? 鲁迅先生早就说过了,落水狗就要痛打。
218 楼 bcccs 2008-11-13  
其实,被培训祸害的人,从我的角度看,越多越好。如果不死人,估计3deer不会爆出什么新闻。总要有人去用命试错。既然和我没什么关系。随便他们去试吧
217 楼 bruce.peng 2008-11-13  
好像那个 什么李刚 出过不少书啊!
216 楼 庄表伟 2008-11-13  
right now 写道
别打击啦,大家消消火,都是中国人,JE不能太过分啊

这个言论真是有趣啊,“好傻,好天真”!
215 楼 wanghuanan 2008-11-13  
引用:
"都是中国人....."


放过一次只会更恶劣,总是要爆发的,呵呵
214 楼 Michael 2008-11-13  
火星叔叔马丁 写道
有新东方title的多来 而且那个是陕西...
田xx不是广东吗?

虽然火星人和v教 主水火不容
但是 哈哈 没有充分证据前 偶主张无罪推论

其实“阴谋论”者去google下“陕西...”就会清楚,你们错了。
213 楼 0701 2008-11-13  
别打击啦,大家消消火,都是中国人,JE不能太过分啊
212 楼 jack 2008-11-13  
还在扯阿,要不这个帖子到各大论坛转贴下,打击的彻底点?
211 楼 sg552 2008-11-13  
又见山寨技术书....无语了。。。。

自己没写书的实力,居然价格还不便宜。

中文资料书,我现在只相信 博文视点的了。
210 楼 wosmvp 2008-11-13  
下一站,火星 写道
你们可能不相信我说的话,举个活生生的例子吧,那个Itian就是个例子,我早就发现这个人有问题,这个人发帖很空洞,一般是上传些资料和展示一些他们的培训系统的例子什么的,而且可以观察到这个人自己不懂ruby,非常喜欢跑到ruby技术区和稀泥,我比较奇怪的是人家讨论ruby和他有什么关系,他做他的java呗,后来偶化名一个mm加他QQ摸清了底细,此人系***集团分公司的一个副总,34岁,聊天记录我还有(5页)。现在的培训市场的情况是这样的,大部分是做java的!很多资深的讲师大都是搞java的,做ror/python等略微新一点的技术的几乎没有,一旦新兴技术发展起来之后,无疑给了培训机构以沉重的打击!所以为了饭碗,他们不得不在JE上大肆宣传他们所培训的那些技术!


火星人果然是神人……

我无聊了下,用百度搜索
Java 对应 9条 推广
.Net 对应 0 推广
Ruby 对应 1 推广,不过与Ruby语言本身无关
C 对应 0 推广
C++ 对应 1 推广
Python ,Perl,D,Erlang,JavaScript,VB……均对应0推广……

Java培训果然无与伦比……
209 楼 ray_linn 2008-11-13  
ddd 写道
bcccs 写道
我一直觉得LZ非常无聊,人家LG也没有动了ReadOnly的奶酪,碍着谁了?培训老师有好的么?
误人子弟?那些人还用误?

我一直觉得bcccs非常无聊,人家readonly也没有动了bcccs的奶酪,碍着谁了?


我觉得也是,如果真bcccs真觉得那么无聊,就不需要来凑一脚...可见是假清高。
208 楼 wanghuanan 2008-11-13  
这贴有益身心健康

还是火星人好,加强偶的判断力
207 楼 ahuaxuan 2008-11-13  
下一站,火星 写道
你们可能不相信我说的话,举个活生生的例子吧,那个Itian就是个例子,我早就发现这个人有问题,这个人发帖很空洞,一般是上传些资料和展示一些他们的培训系统的例子什么的,而且可以观察到这个人自己不懂ruby,非常喜欢跑到ruby技术区和稀泥,我比较奇怪的是人家讨论ruby和他有什么关系,他做他的java呗,后来偶化名一个mm加他QQ摸清了底细,此人系***集团分公司的一个副总,34岁,聊天记录我还有(5页)。现在的培训市场的情况是这样的,大部分是做java的!很多资深的讲师大都是搞java的,做ror/python等略微新一点的技术的几乎没有,一旦新兴技术发展起来之后,无疑给了培训机构以沉重的打击!所以为了饭碗,他们不得不在JE上大肆宣传他们所培训的那些技术!


当时我在ruby区看到他和gigix吵,我就觉得挺奇怪的,一个不怎么懂ruby的人吵来吵去,难道真的这么无聊?

看到这个暴料才知道原来他是有目的的,真实居心叵测啊.

既然如此,那javaeye就搞一个"视线培训",专门培训ruby和python相关的,和他抢市场.




206 楼 阳光晒晒 2008-11-13  
eyejava 写道
下一站,火星 写道
你们可能不相信我说的话,举个活生生的例子吧,那个Itian就是个例子,我早就发现这个人有问题,这个人发帖很空洞,一般是上传些资料和展示一些他们的培训系统的例子什么的,而且可以观察到这个人自己不懂ruby,非常喜欢跑到ruby技术区和稀泥,我比较奇怪的是人家讨论ruby和他有什么关系,他做他的java呗,后来偶化名一个mm加他QQ摸清了底细,此人系***集团分公司的一个副总,34岁,聊天记录我还有(5页)。现在的培训市场的情况是这样的,大部分是做java的!很多资深的讲师大都是搞java的,做ror/python等略微新一点的技术的几乎没有,一旦新兴技术发展起来之后,无疑给了培训机构以沉重的打击!所以为了饭碗,他们不得不在JE上大肆宣传他们所培训的那些技术!


这个...
如果新技术有完全优势,他们不至于傻到去螳臂挡车吧,拖住历史前进的车轮 ? 

可以出书么....培训转型也要时间么
205 楼 eyejava 2008-11-13  
下一站,火星 写道
你们可能不相信我说的话,举个活生生的例子吧,那个Itian就是个例子,我早就发现这个人有问题,这个人发帖很空洞,一般是上传些资料和展示一些他们的培训系统的例子什么的,而且可以观察到这个人自己不懂ruby,非常喜欢跑到ruby技术区和稀泥,我比较奇怪的是人家讨论ruby和他有什么关系,他做他的java呗,后来偶化名一个mm加他QQ摸清了底细,此人系***集团分公司的一个副总,34岁,聊天记录我还有(5页)。现在的培训市场的情况是这样的,大部分是做java的!很多资深的讲师大都是搞java的,做ror/python等略微新一点的技术的几乎没有,一旦新兴技术发展起来之后,无疑给了培训机构以沉重的打击!所以为了饭碗,他们不得不在JE上大肆宣传他们所培训的那些技术!


这个...
如果新技术有完全优势,他们不至于傻到去螳臂挡车吧,拖住历史前进的车轮 ? 
204 楼 cats_tiger 2008-11-13  
庄表伟 写道

gigix 写道下一站,火星 写道其实事情就是这么个事情,我的看法是不能把他们逼的太厉害,总得留口饭给别人!此贴可以休矣,锁定吧,主要是不想让Robbin又扯上什么法律问题,这帮人非常厉害,什么对策都有!最好做个互不干涉的申明,那帮愿意往培训机构里面跳的人其实和我们一毛钱的关系也没有!
本着看热闹就要看到底的八卦精神,其实我很想看看把他们逼急了到底会发生什么


哈哈,我也想看看。


也想看的飘过~~~
203 楼 下一站,火星 2008-11-13  
<div class='quote_title'>gigix 写道</div>
<div class='quote_div'>
<div class='quote_title'>下一站,火星 写道</div>
<div class='quote_div'>其实事情就是这么个事情,我的看法是不能把他们逼的太厉害,总得留口饭给别人!此贴可以休矣,锁定吧,主要是不想让Robbin又扯上什么法律问题,这帮人非常厉害,什么对策都有!最好做个互不干涉的申明,那帮愿意往培训机构里面跳的人其实和我们一毛钱的关系也没有!</div>
<br/>本着看热闹就要看到底的八卦精神,其实我很想看看把他们逼急了到底会发生什么<br/><img src='/images/smiles/icon_evil.gif' alt=''/> </div>
<p> </p>
<p>偶没看过李老师的书,也不知道书写的怎么样,先申明,李老师的恩恩怨怨,和偶一毛钱的关系也没有!</p>
<p> </p>
<p>我只是想说那帮有着不良动机的人,以后少去水偶的帖子,你做你的培训,不要来惹我!</p>
202 楼 庄表伟 2008-11-13  
gigix 写道
下一站,火星 写道
其实事情就是这么个事情,我的看法是不能把他们逼的太厉害,总得留口饭给别人!此贴可以休矣,锁定吧,主要是不想让Robbin又扯上什么法律问题,这帮人非常厉害,什么对策都有!最好做个互不干涉的申明,那帮愿意往培训机构里面跳的人其实和我们一毛钱的关系也没有!

本着看热闹就要看到底的八卦精神,其实我很想看看把他们逼急了到底会发生什么


哈哈,我也想看看。
201 楼 gigix 2008-11-13  
下一站,火星 写道
其实事情就是这么个事情,我的看法是不能把他们逼的太厉害,总得留口饭给别人!此贴可以休矣,锁定吧,主要是不想让Robbin又扯上什么法律问题,这帮人非常厉害,什么对策都有!最好做个互不干涉的申明,那帮愿意往培训机构里面跳的人其实和我们一毛钱的关系也没有!

本着看热闹就要看到底的八卦精神,其实我很想看看把他们逼急了到底会发生什么

相关推荐

    Ruby on Rails Guides v2 - Ruby on Rails 4.2.5

    ### Ruby on Rails Guides v2 - Ruby on Rails 4.2.5 #### 一、重要概念及基础假设 - **重要概念**:本指南旨在帮助读者深入理解Ruby on Rails(以下简称Rails)4.2.5版本的核心功能与最佳实践。 - **基础假设**:...

    转载 - 26本 Ruby/Rails 相关英文图书简评

    Ruby 和 Rails 是两种非常重要的 IT 技术,它们在软件开发领域中占据着重要的地位。Ruby 是一种面向对象的、动态类型的编程语言,以其简洁、优雅的语法和强大的元编程能力而闻名。Rails,全称为 Ruby on Rails,是...

    Ruby - Ruby for Rails

    ### 一、Ruby/Rails 景观 #### 1.1 如何理解 Ruby 的工作原理 - **基础概念**:介绍 Ruby 作为一种动态类型的面向对象编程语言的基础知识。 - **解释器与虚拟机**:讲解 Ruby 是如何通过解释器或虚拟机运行的。 - *...

    征服-Ruby On Rails.rar

    Ruby on Rails,简称Rails,是一种基于Ruby编程语言的开源Web应用程序框架,它遵循MVC(模型-视图-控制器)架构模式,旨在提高开发效率,强调简洁和生产力。Rails的核心理念是“Don't Repeat Yourself”(DRY)和...

    Packt - Ruby on Rails Enterprise Application Development (Oct 2007)

    《Ruby on Rails企业应用程序开发》是一本面向专业开发者和对企业级应用有需求的读者的经典教程。这本书详尽地探讨了如何使用Ruby on Rails框架来构建高效、可扩展且可靠的大型企业级应用程序。Ruby on Rails(简称...

    bugsnag-ruby, Rails Sinatra rack 和 ruby的Bugsnag错误监视.zip

    bugsnag-ruby, Rails Sinatra rack 和 ruby的Bugsnag错误监视 ruby的 Bugsnag异常报告器 ruby 异常报告器提供了从你的 Rails Sinatra/英镑/或者英镑的普通 ruby 应用程序中抛出的异常通知。 任何未捕获的异常都会...

    Ruby-on-Rails-rails.zip

    Ruby_on_Rails_rails.zip Ruby_on_Rails_rails.zip Ruby_on_Rails_rails.zip Ruby_on_Rails_rails.zipRuby_on_Rails_rails.zip Ruby_on_Rails_rails.zip Ruby_on_Rails_rails.zip Ruby_on_Rails_rails.zipRuby_on_...

    College-Management-System---Ruby-On-Rails:Ruby On Rails-CMS

    学院管理系统-Ruby on Rails 学校/学院管理系统 该系统是一个非常全面的系统,并且在考虑到学校和学院功能的前提下进行了清晰的查看。 它使用以下技术构建- Ruby On Rails Bootsrap(CSS / JavaScript框架) ...

    Wrox - Beginning Ruby on Rails

    该书由经验丰富的技术作家Steven Holzner撰写,内容全面覆盖了Ruby on Rails的基础知识,并提供了丰富的示例代码和实践项目,非常适合那些想要快速上手Ruby on Rails的新手开发者。 #### 三、书籍内容概览 - **Ruby...

    Ruby on Rails Tutorial

    《Ruby on Rails Tutorial》中文版(原书第2版,涵盖 Rails 4) Ruby 是一门很美的计算机语言,其设计原则就是“让编程人员快乐”。David Heinemeier Hansson 就是看重了这一点,才在开发 Rails 框架时选择了 Ruby...

    hello-ruby-rails:一个基于Rails的简单hasura项目

    你好Ruby路轨 本快速入门由使用Rails的基本Hasura项目组成。 将项目部署到Hasura集群后,您将在运行Rails应用程序 如果您打算使用Hasura构建或想学习构建Rails应用程序,那么这是一个正确的起点。 步骤1:取得专案 $...

    Ruby on Rails入门经典代码

    Ruby on Rails,简称Rails,是基于Ruby语言的一个开源Web应用程序框架,它遵循MVC(Model-View-Controller)架构模式,旨在使Web开发过程更加高效、简洁。本压缩包中的"Ruby on Rails入门经典代码"提供了新手学习...

    ruby on rails 101

    引用自Nathan Torkington的话:“使用Ruby on Rails就像观看功夫电影一样,看似弱小的新手框架却能够用各种创造性的方式打败众多强大的对手。”这句话生动地描述了Ruby on Rails的独特之处以及它在Web开发领域的影响...

    Packt - Ruby on Rails Web Mashup Projects (Apr 2008)

    《Ruby on Rails Web混合项目》 英文PDF + 源码

    Ruby-GoOnRails使用Rails生成器来生成一个Golang应用

    **Ruby-GoOnRails:利用Rails生成器构建Golang应用** Ruby on Rails(简称Rails)是一种流行的Web开发框架,以其“约定优于配置”的理念和高效的开发速度受到开发者喜爱。而Go(Golang)则是一种静态类型、编译型的...

Global site tag (gtag.js) - Google Analytics