# 9.5 小結
我們用了好幾章介紹如何實現用戶資源,在 [5.4 節](chapter5.html#user-signup-a-first-step)用戶還不能注冊,而現在不僅可以注冊,還可以登錄、退出、查看個人信息、修改信息,還能瀏覽網站中所有用戶的列表,某些用戶甚至可以刪除其他用戶。
現階段實現的演示應用建立了堅實的基礎,完全可用于任何需要認證用戶和權限系統的網站。[第 10 章](chapter10.html#account-activation-and-password-reset)會實現兩個附加功能:向新注冊的用戶發送賬戶激活鏈接(同時驗證電子郵件地址有效),以及密碼重設功能,幫助忘記密碼的用戶。
在繼續閱讀之前,先把本章所做的改動合并到 `master` 分支:
```
$ git add -A
$ git commit -m "Finish user edit, update, index, and destroy actions"
$ git checkout master
$ git merge updating-users
$ git push
```
你還可以部署這個應用,甚至使用示例用戶填充生產數據庫(`pg:reset` 用于還原生產數據庫):
```
$ bundle exec rake test
$ git push heroku
$ heroku pg:reset DATABASE
$ heroku run rake db:migrate
$ heroku run rake db:seed
$ heroku restart
```
當然,在真實的網站中你或許并不想向數據庫中添加示例數據,我加入這個操作只是為了查看生產環境中的效果([圖 9.16](#fig-heroku-sample-users))。生產環境顯示的示例用戶順序各異,我的網站顯示的順序就和本地不同([圖 9.11](#fig-user-index-pagination))。這是因為,我們沒有指定從數據庫中取回用戶的順序,所以目前的順序由數據庫決定。這對用戶而言沒什么問題,但微博就不同了,我們會在 [11.1.4 節](chapter11.html#micropost-refinements)解決這個問題。
圖 9.16:生產環境顯示的示例用戶
## 9.5.1 讀完本章學到了什么
* 可以使用編輯表單修改用戶的資料,這個表單向 `update` 動作發送 `PATCH` 請求;
* 為了提升通過 Web 修改信息的安全性,必須使用“健壯參數”;
* 事前過濾器是在控制器動作前執行方法的標準方式;
* 我們使用事前過濾器實現了權限系統;
* 針對權限系統的測試既使用了低層命令直接向控制器動作發送適當的 HTTP 請求,也使用了高層的集成測試;
* 友好轉向會在用戶登錄后重定向到之前想訪問的頁面;
* 用戶列表頁面列出了所有用戶,而且一頁只顯示一部分用戶;
* Rails 使用標準的文件 `db/seeds.rb` 向數據庫中添加示例數據,這個操作使用 `rake db:seed` 任務完成;
* `render @users` 會自動調用 `_user.html.erb` 局部視圖,渲染集合中的各個用戶;
* 在用戶模型中添加 `admin` 布爾值屬性后,會自動創建 `user.admin?` 布爾值方法;
* 管理員點擊刪除鏈接可以刪除用戶,點擊刪除鏈接后會向用戶控制器的 `destroy` 動作發起 `DELETE` 請求;
* 在固件中可以使用嵌入式 Ruby 創建大量測試用戶。
- 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 練習