# 8.5 小结
这两章我们介绍了很多基础知识,也为稍显简陋的应用实现了注册和登录功能。实现用户认证功能后,我们可以根据登录状态和用户的身份限制对特定页面的访问权限。我们会在[第 9 章](chapter9.html#updating-showing-and-deleting-users)实现编辑用户个人信息的功能。
在继续之前,先把本章的改动合并到 `master` 分支:
```
$ bundle exec rake test
$ git add -A
$ git commit -m "Finish log in/log out"
$ git checkout master
$ git merge log-in-log-out
```
然后再推送到远程仓库和生产服务器:
```
$ bundle exec rake test
$ git push
$ git push heroku
$ heroku run rake db:migrate
```
注意,推送后应用基本上处于不可用状态,不过执行迁移之后就没问题了。在拥有巨大流量的线上网站中,更新前最好开启[维护模式](https://devcenter.heroku.com/articles/maintenance-mode):
```
$ heroku maintenance:on
$ git push heroku
$ heroku run rake db:migrate
$ heroku maintenance:off
```
这样,在部署和执行迁移期间会显示一个标准的错误页面。详情参见 Heroku 文档中对[错误页面](https://devcenter.heroku.com/articles/error-pages)的说明。
## 8.5.1 读完本章学到了什么
* Rails 可以使用临时 cookie 和持久 cookie 维护页面之间的状态;
* 登录表单的目的是创建新会话,登入用户;
* `flash.now` 方法用于在重新渲染的页面中显示闪现消息;
* 在测试中重现问题时可以使用测试驱动开发;
* 使用 `session` 方法可以安全地在浏览器中存储用户 ID,创建临时会话;
* 可以根据登录状态修改功能,例如布局中显示的链接;
* 集成测试可以检查路由、数据库更新和对布局的修改;
* 为了实现持久会话,我们为每个用户生成了记忆令牌和对应的记忆摘要;
* 使用 `cookies` 方法可以在浏览器的 cookie 中存储一个永久记忆令牌,实现持久会话;
* 登录状态取决于有没有当前用户,而当前用户通过临时会话中的用户 ID 或持久会话中唯一的记忆令牌获取;
* 退出功能通过删除会话中的用户 ID 和浏览器中的持久 cookie 实现;
* 三元操作符是编写简单 `if-else` 语句的简洁方式。
- Ruby on Rails 教程
- 致中国读者
- 序
- 致谢
- 作者译者简介
- 版权和代码授权协议
- 第 1 章 从零开始,完成一次部署
- 1.1 简介
- 1.2 搭建环境
- 1.3 第一个应用
- 1.4 使用 Git 做版本控制
- 1.5 部署
- 1.6 小结
- 1.7 练习
- 第 2 章 玩具应用
- 2.1 规划应用
- 2.2 用户资源
- 2.3 微博资源
- 2.4 小结
- 2.5 练习
- 第 3 章 基本静态的页面
- 3.1 创建演示应用
- 3.2 静态页面
- 3.3 开始测试
- 3.4 有点动态内容的页面
- 3.5 小结
- 3.6 练习
- 3.7 高级测试技术
- 第 4 章 Rails 背后的 Ruby
- 4.1 导言
- 4.2 字符串和方法
- 4.3 其他数据类型
- 4.4 Ruby 类
- 4.5 小结
- 4.6 练习
- 第 5 章 完善布局
- 5.1 添加一些结构
- 5.2 Sass 和 Asset Pipeline
- 5.3 布局中的链接
- 5.4 用户注册:第一步
- 5.5 小结
- 5.6 练习
- 第 6 章 用户模型
- 6.1 用户模型
- 6.2 用户数据验证
- 6.3 添加安全密码
- 6.4 小结
- 6.5 练习
- 第 7 章 注册
- 7.1 显示用户的信息
- 7.2 注册表单
- 7.3 注册失败
- 7.4 注册成功
- 7.5 专业部署方案
- 7.6 小结
- 7.7 练习
- 第 8 章 登录和退出
- 8.1 会话
- 8.2 登录
- 8.3 退出
- 8.4 记住我
- 8.5 小结
- 8.6 练习
- 第 9 章 更新,显示和删除用户
- 9.1 更新用户
- 9.2 权限系统
- 9.3 列出所有用户
- 9.4 删除用户
- 9.5 小结
- 9.6 练习
- 第 10 章 账户激活和密码重设
- 10.1 账户激活
- 10.2 密码重设
- 10.3 在生产环境中发送邮件
- 10.4 小结
- 10.5 练习
- 10.6 证明超时失效的比较算式
- 第 11 章 用户的微博
- 11.1 微博模型
- 11.2 显示微博
- 11.3 微博相关的操作
- 11.4 微博中的图片
- 11.5 小结
- 11.6 练习
- 第 12 章 关注用户
- 12.1 “关系”模型
- 12.2 关注用户的网页界面
- 12.3 动态流
- 12.4 小结
- 12.5 练习