# 19. CURD 实践之为新添加的属性修改注册功能
之前为 `user` 表添加了两个属性,分别是 `username` 和 `dob`。
现在我们来试一下注册功能,如下所示:
![](https://box.kancloud.cn/1ee825730639211a1a246a0a838b5e70_2616x1144.gif)
报错了!,报错的内容如下:
```
SQLSTATE[HY000]: General error: 1364 Field 'username' doesn't have a default value
(SQL: insert into `users` (`name`, `email`, `password`, `updated_at`, `created_at`)
values (1111, hfpp2012111222@gmail.com11, $2y$10$aJOC/aceiBf3bWh5iIGejOkNLKXXYatLo4X.KEftiRslsdyfP5mTW, 2017-09-08 03:56:19, 2017-09-08 03:56:19))
```
大体意思是说,`username` 没有默认值,就是说我们没有给 `username` 填充值。
我们分为三步来解决这个问题。
## 1. 加上 view
先给 `username` 和 `dob` 这两个属性在前端上加上可以填写的 view,当用户注册的时候就可以填写用户名和出生日期。
找到注册的 view 文件:`resources/views/auth/register.blade.php`。
找准位置,加上下面这两段代码:
```
<!-- 用户名 -->
<div class="form-group{{ $errors->has('username') ? ' has-error' : '' }}">
<label for="username" class="col-md-4 control-label">UserName</label>
<div class="col-md-6">
<input id="username" type="text" class="form-control" name="username" value="{{ old('username') }}" required autofocus>
@if ($errors->has('username'))
<span class="help-block">
<strong>{{ $errors->first('username') }}</strong>
</span>
@endif
</div>
</div>
<!-- 出生日期 -->
<div class="form-group{{ $errors->has('dob') ? ' has-error' : '' }}">
<label for="dob" class="col-md-4 control-label">Dob</label>
<div class="col-md-6">
<input id="dob" type="date" class="form-control" name="dob" value="{{ old('dob') }}" required autofocus>
@if ($errors->has('dob'))
<span class="help-block">
<strong>{{ $errors->first('dob') }}</strong>
</span>
@endif
</div>
</div>
```
## 2. 更改 controller
view 改好了,controller 要接受新的字段,来修改一下。
找到 `app/Http/Controllers/Auth/RegisterController.php` 文件,打开之后,找到 `create` 方法,修改如下:
```
// app/Http/Controllers/Auth/RegisterController.php
protected function create(array $data)
{
return User::create([
'name' => $data['name'],
'email' => $data['email'],
'password' => $data['password'],
// 下面两行是新增的
'username' => $data['username'],
'dob' => $data['dob'],
]);
}
```
## 3. 修改 model
这样还不行,需要修改一下 model, 这个有点像 `rails` 的 [Strong Parameters](http://edgeapi.rubyonrails.org/classes/ActionController/StrongParameters.html)的功能。
找到 `app/User.php` 方法,找到 `$fillable` 属性,修改如下:
```
protected $fillable = [
// 新增了 username 和 dob
'name', 'email', 'password', 'username', 'dob'
];
```
这样数据表 `users` 就可以存这两个属性了。
最后再试下注册功能,效果如下:
![](https://box.kancloud.cn/06bdc8b0eee480950e7fa82f16655b4b_2602x1296.gif)
完结。
- 0. 介绍
- 1. php 开发环境安装
- 2. 跑 laravel 的 hello world
- 3. 第一个路由 UsersController
- 4. 在数据库中创建一条数据
- 5. 简单的用户认证
- 6. 修改 User model
- 7. User model 的 getter 方法
- 8. view 的更多知识
- 9. 在 view 中共享变量
- 10. blade layout
- 11. 使用 @include 来整理 view
- 12. Blade if/else/unless/or
- 13. factories, faker and seeding
- 14. Blade foreach
- 15. 分页
- 16. 用中间件来限制用户必须登录
- 17. Route group
- 18. CURD 实践之改变用户表结构
- 19. CURD 实践之为新添加的属性修改注册功能
- 20. CURD 实践之用 username 来代替 email 登录
- 21. CURD 个人中心页面
- VIM 的 laravel 插件
- VIM 中有效地查看 php 源码