# 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 練習