首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > 网络技术 > 网络基础 >

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

2012-11-10 
师傅领错门,害了你个人 - ruby/rails新手避免入错门最近看到一位Ruby On Rails新手写的代码,简直是惨不忍

师傅领错门,害了你个人 - 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] = "激活失败!"  endend

而且在实际开发中,作为最佳实践,最后一个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的书给他,让他好好改造去了... 269 楼 nnnnon 2008-12-02   这样不好吧! 270 楼 sg552 2008-12-03   ozzzzzz 写道sg552 写道又见山寨技术书....无语了。。。。

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

中文资料书,我现在只相信 博文视点的了。
你看清楚了没,李刚的书都是谁出版的?还只相信博文视点。
http://www.broadview.com.cn/
看看那个“Java引领技术人生”专题讲座北京、上海站圆满举行。
看见没,这个了李刚就是博文视点给炮制出来的明星作家。


真晕。。。。 博文视点的?  我确实没看清楚。

好吧。那我把我的说法改一下,

以后只敢读博文视点的 Pragmatic 系列的了。。。。


PS。这本书上周六我在西单图书大厦见到了。纸质很差,页面的设计风格也难看。
里面的内容繁多,把java入门搞的巨复杂。再看到他提倡“通宵编程”我就翻不下去了。
哎。他的公司居然在华南师范大学里,可怜了里面的MM们。。。
271 楼 savegod 2008-12-30   现在好多培训机构的老师似乎之前都不是计算机专业出身的半路和尚。。。 272 楼 mayday85 2008-12-30   savegod 写道现在好多培训机构的老师似乎之前都不是计算机专业出身的半路和尚。。。

敢问你是谁的马甲
开始掘坟 273 楼 longrm 2009-02-22   坚定支持lz的立场 274 楼 longrm 2009-02-22   jkfzero 写道AWDWR2的东西没法照着一步一步做呀,如果rails2.0版本的话。
3还没出吧?
现在看什么学比较好?
最近也打算学ruby,AWDWRII的东西上手难么 275 楼 jkfzero 2009-02-22   longrm 写道jkfzero 写道AWDWR2的东西没法照着一步一步做呀,如果rails2.0版本的话。
3还没出吧?
现在看什么学比较好?
最近也打算学ruby,AWDWRII的东西上手难么
还好吧,我以前接触过ruby的。
rails的东西最新版的和书上写的有些不同呀,不过挨个解决问题倒是很有成就感,就是稍微有点浪费时间。
你可以试试用旧版本来学习。 276 楼 夜鸣猪 2009-03-29   赞啊,

对于李某说他啥好啊,幸好啊,幸好啊

还有出来说话,

仔细看看,

这家伙还真是害人啊

要知道他那本书,似乎现在买的还不错呢 277 楼 night_stalker 2009-03-29   这山寨教程,光“大全”这两个字就把我吓跑了…… 278 楼 Hooopo 2009-04-28   呼呼,,那书好厚呀~~ 279 楼 geminiyellow 2009-04-28   ……又挖出来了,那书确实很厚啊,但是封面太难看了,没勾起我翻书的欲望啊。 280 楼 eclipse2008 2009-08-02   新东方看来是笼子大了。

热点排行