# 2.1 规划应用
这一节,我们要规划一下这个玩具应用。和 [1.3 节](chapter1.html#the-first-application)一样,我们先使用 `rails new` 命令生成应用的骨架。
```
$ cd ~/workspace
$ rails _4.2.2_ new toy_app
$ cd toy_app/
```
如果执行 `rails new` 命令后看到“Could not find “railties””这样的错误,说明你安装的 Rails 版本不对。再次确认安装 Rails 时执行的命令和[代码清单 1.1](chapter1.html#listing-installing-rails) 一模一样。(注意,如果使用[1.2.1 节](chapter1.html#development-environment)推荐的云端 IDE,这个应用可以在第一个应用所在的工作空间中创建,没必要再新建一个工作空间。如果没看到文件,可以点击文件浏览器中的齿轮图标,然后选择“Refresh File Tree”(刷新文件树)。)
然后,在文本编辑器中修改 `Gemfile`,写入[代码清单 2.1](#listing-demo-gemfile-sqlite-version-redux) 中的内容。
##### 代码清单 2.1:这个玩具应用的 `Gemfile`
```
source 'https://rubygems.org'
gem 'rails', '4.2.2'
gem 'sass-rails', '5.0.2'
gem 'uglifier', '2.5.3'
gem 'coffee-rails', '4.1.0'
gem 'jquery-rails', '4.0.3'
gem 'turbolinks', '2.3.0'
gem 'jbuilder', '2.2.3'
gem 'sdoc', '0.4.0', group: :doc
group :development, :test do
gem 'sqlite3', '1.3.9'
gem 'byebug', '3.4.0'
gem 'web-console', '2.0.0.beta3'
gem 'spring', '1.1.3'
end
group :production do
gem 'pg', '0.17.1'
gem 'rails_12factor', '0.0.2'
end
```
注意,[代码清单 2.1](#listing-demo-gemfile-sqlite-version-redux) 和[代码清单 1.14](chapter1.html#listing-gemfile-pg-gem) 的内容一样。
和 [1.5.1 节](chapter1.html#heroku-setup)一样,安装 gem 时要指定 `--without production` 选项,不安装生产环境所需的 gem:
```
$ bundle install --without production
```
最后,把这个玩具应用纳入 Git 版本控制系统:
```
$ git init
$ git add -A
$ git commit -m "Initialize repository"
```
你还可以在 Bitbucket 网站中点击“Create”(新建)按钮[创建一个新仓库](https://bitbucket.org/repo/create)([图 2.1](#fig-create-demo-repository)),然后把代码推送到这个远程仓库中:
```
$ git remote add origin git@bitbucket.org:<username>/toy_app.git
$ git push -u origin --all # 首次推送这个仓库
```
![create demo repo bitbucket](https://box.kancloud.cn/2016-05-11_5732bcb0b864c.png)图 2.1:在 Bitbucket 中为这个玩具应用创建一个仓库
越早部署应用越好。我建议把[代码清单 1.8](chapter1.html#listing-hello-action) 和[代码清单 1.9](chapter1.html#listing-default-root-route) 中的内容复制过来,[[1](#fn-1)]然后提交改动,再推送到 Heroku:
```
$ git commit -am "Add hello"
$ heroku create
$ git push heroku master
```
(和 [1.5 节](chapter1.html#deploying)一样,可能会看到一些提醒消息,现在先不去管它。[7.5 节](chapter7.html#professional-grade-deployment)会解决。)除了 Heroku 为应用提供的地址之外,输出的内容应该和[图 1.18](chapter1.html#fig-heroku-app) 一样。
下面要开发这个应用了。一般来说,开发 Web 应用的第一步是创建数据模型(data model)。模型表示应用所需的结构。这个玩具应用是个微博客,只有用户和简短的文章(微博)。那么我们先为这个应用添加用户模型([2.1.1 节](#a-toy-model-for-users)),然后再添加微博模型([2.1.2 节](#a-toy-model-for-microposts))。
## 2.1.1 用户模型
网络中有多少不同的注册表单,就有多少定义用户数据模型的方式。我们要使用一种最简单的。这个玩具应用的用户有一个唯一的标识 `id`(`integer` 类型),一个公开的名字 `name`(`string` 类型),以及一个电子邮件地址 `email`(也是 `string` 类型)。电子邮件地址也作为用户名使用。用户模型的结构如[图 2.2](#fig-demo-user-model)。
![demo user model](https://box.kancloud.cn/2016-05-11_5732bcb0ce3de.png)图 2.2:用户数据模型
在 [6.1.1 节](chapter6.html#database-migrations)会看到,[图 2.2](#fig-demo-user-model) 中的 `users` 对应于数据库中的一个表;`id`、`name` 和 `email` 是表中的列。
## 2.1.2 微博模型
微博数据模型的核心比用户模型还要简单:微博只要一个 `id` 和表示微博内容的 `content`(`text` 类型)字段即可。[[2](#fn-2)]不过还有一个比较复杂的字段要实现,这个字段把微博和用户关联起来。我们使用 `user_id` 存储微博的属主。最终得到的微博数据模型如[图 2.3](#fig-demo-micropost-model) 所示。
![demo micropost model](https://box.kancloud.cn/2016-05-11_5732bcb0e165f.png)图 2.3:微博数据类型
[2.3.3 节](#a-user-has-many-microposts)会介绍怎样使用 `user_id` 字段简单的实现一个用户拥有多个微博的功能。在[第 11 章](chapter11.html#user-microposts)中有更完整的说明。
- 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 练习