# 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)解决这个问题。
![heroku sample users](https://box.kancloud.cn/2016-05-11_573330618d298.png)图 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 练习