6.4 小结

本章从零开始建立了一个可以正常使用的用户模型,创建了 nameemailpassword 属性,还为这些属性制定了重要的取值约束规则。而且,已经可以使用密码对用户进行认证了。整个用户模型只用了十行代码。

在接下来的第 7 章,我们会创建一个注册表单,用来新建用户,还会创建一个页面,显示用户的信息。第 8 章会使用 6.3 节实现的认证机制让用户登录网站。

如果使用 Git,而且一直都没提交,现在是提交的好时机:

$ bundle exec rake test
$ git add -A
$ git commit -m "Make a basic User model (including secure passwords)"

然后合并到主分支,再推送到远程仓库中:

$ git checkout master
$ git merge modeling-users
$ git push

为了让用户模型在生产环境中能正常使用,我们要在 Heroku 中执行迁移。这个操作可以通过 heroku run 命令完成:

$ bundle exec rake test
$ git push heroku
$ heroku run rake db:migrate

我们可以在生产环境的控制台中执行以下代码确认一下:

$ heroku run console --sandbox
>> User.create(name: "Michael Hartl", email: "[email protected]",
?>             password: "foobar", password_confirmation: "foobar")
=> #<User id: 1, name: "Michael Hartl", email: "[email protected]",
created_at: "2014-08-29 03:27:50", updated_at: "2014-08-29 03:27:50",
password_digest: "$2a$10$IViF0Q5j3hsEVgHgrrKH3uDou86Ka2lEPz8zkwQopwj...">

6.4.1 读完本章学到了什么

  • 使用迁移可以修改应用的数据模型;

  • Active Record 提供了很多创建和处理数据模型的方法;

  • 使用 Active Record 验证可以在模型的数据上添加约束条件;

  • 常见的验证有存在性、长度和格式;

  • 正则表达式晦涩难懂,但功能强大;

  • 数据库索引可以提升查询效率,而且能在数据库层实现唯一性约束;

  • 可以使用内置的 has_secure_password 方法在模型中添加一个安全的密码。