Laravel 5.1 文档攻略 —— Eloquent: 读取器和修饰器
简介
这一章其实很简单,Model的属性不是和数据表的字段一一对应吗?
那么在存储和呈现数据的时候,我们有时会需要预先对数据一些处理。比如为了保密,我们可以利用Laravel encrypter
在数据库里存加密的数据,别人拿去也没用,我们可以把一段解密程序放在model里,只有通过model里的解密程序才能把数据解密并呈现出来;
除了可以改模型的属性值,Eloquent还可以改属性(字段)的数据类型。
读取器和修饰器(Accessors & Mutators)
一看到这两个字,马上高大尚了,Accessors & Mutators 也就是 Getter 和 Setter, 是数据存储前后的一些预处理方法。这一般是Java,C#这些”高级”的语言说法,Taylor把它用在屌丝PHP这里了,然而并无违和感。
读取器
namespace App;
use Illuminate\Database\Eloquent\Model;
class User extends Model
{
public function getFirstNameAttribute($value)
{
return ucfirst($value);
}
}
既然是get,就是在从数据库读数据的时候对数据进行修改;
注意getFirstNameAttribute
这个写法,这是个魔术方法,FirstName是你的字段名,需要用驼峰命名法;
方法内你就可以对字段值(属性值)进行处理;
例子是把首字母转化为大写了。
$user = App\User::find(1);
$firstName = $user->first_name;
回头你在使用属性的时候,发现first_name的值首字母自动变成大写了。
修饰器
namespace App;
use Illuminate\Database\Eloquent\Model;
class User extends Model
{
public function setFirstNameAttribute($value)
{
$this->attributes['first_name'] = strtolower($value);
}
}
既然是set方法,那么肯定是写入数据之前对数据进行处理;
上面这个例子是把名字全变成小写字母存入数据库(包括对象的属性也会自动转换为小写)。
日期修饰器(Mutators)
Eloquent的模型会自动将日期类型字段进行修饰处理,例如默认的created_at
和updated_at
字段,在模型里,它们会自动转换成为Carbon类的对象,Carbon类里有很多用来处理时间方法。
namespace App;
use Illuminate\Database\Eloquent\Model;
class User extends Model
{
protected $dates = ['created_at', 'updated_at', 'deleted_at'];
}
这里就指定了那些字段是属于日期类型的字段。
在模型中指定为日期类型的字段后,你可以使用 UNIX 时间戳, date string (Y-m-d)格式,date-time string和Carbon类对象等方式给该字段赋值:
$user = App\User::find(1);
$user->deleted_at = Carbon::now();
$user->save();
下面说一个比较特殊的点:
$user = App\User::find(1);
return $user->created_at->getTimestamp();
假设你打印$user
,你会发现它大概是这样的:
App\Models\User {#1270
id: 8,
name: "woody",
email: "72727921@qq.com",
active: 1,
created_at: "2015-08-05 07:27:09",
updated_at: "2015-09-16 01:34:36",
}
但是如果你打印$user->created_at
, 你会发现它被自动转哈为Carbon对象:
Carbon\Carbon {#1267
+"date": "2015-08-05 07:27:09.000000",
+"timezone_type": 3,
+"timezone": "UTC",
}
所以后面可以接Carbon的各种方法。但是,如果你在blade视图中直接使用{{$user->created_at}}
, 出来将是字符串类型。
默认的日期存储格式是Y-m-d H:i:s
, 你可以改model的$dateFormat
属性来改变格式:
namespace App;
use Illuminate\Database\Eloquent\Model;
class Flight extends Model
{
protected $dateFormat = 'U';
}
注意,这个格式不仅将影响日期在数据库中的存储格式,还将影响模型在转换成为数组或json时,日期字段的保存格式。
属性数值类型转换
从数据读出来的值,有时候你不仅希望改变它的值,还想改变它的数值类型。当然,你可以用accessor实现这一点,但laravel 提供了更直接的方法$cast。解释一下cast的语义,cast不是改变,而是暂时转换。
假设is_admin是以0,1整数的形式在数据库中存储的,
<?php
namespace App;
use Illuminate\Database\Eloquent\Model;
class User extends Model
{
protected $casts = [
'is_admin' => 'boolean',
];
}
那么,这样设置过后读出来将是布尔值;
数组类型转换
有一个应用场景很常见,就是有些字段我们是以json序列化格式存入数据的,比如一组图片,一批选项值;
这个时候我们用这些值的时候要反序列化,每次都要处理很麻烦,这里我们可以用:
<?php
namespace App;
use Illuminate\Database\Eloquent\Model;
class User extends Model
{
protected $casts = [
'options' => 'array',
];
}
这样,对于options这个字段,每次读出来的就是一个数组了,方便在PHP里使用。
$user = App\User::find(1);
$options = $user->options;
$options['key'] = 'value';
$user->options = $options;
$user->save();
看到没有,取出来当数组使用,存回去的时候数组存回去,存到数据库里面自动序列化变string。
Laravel 5.1 文档攻略 —— Eloquent: 读取器和修饰器的更多相关文章
- Laravel 5.1 文档攻略 —— Eloquent:模型对象序列化
在写api的时候,数据一般是以json格式进行传输的,没有对象可以直接使用.这个时候,对数据的序列化转换就很重要,Eloquent提供了很方便的方法和约定,不仅可以转换,还可以控制里面的键值. 基本用 ...
- Laravel 5.1 文档攻略 —— Eloquent Collection
简介 像all()和get(),还有一些处理模型关系这种会返回多条数据的方法,在Eloquent里面会返回一个collection对象集合(对象装在对象里),而不是像DQB的数组结果集合(对象装在数组 ...
- Laravel 5.1 文档攻略 —— Eloquent:模型关系
简介 其实大家都知道,数据表之间都是可以关联的,前面讲过了,Eloquent ORM是数据模型操作代替表操作,那么表的关联查询,在Eloquent这里也就是模型间的关联查询,这就是本章的主要内容: E ...
- [ Laravel 5.5 文档 ] 处理用户请求 —— HTTP 请求的过滤器:中间件
[ Laravel 5.5 文档 ] 处理用户请求 —— HTTP 请求的过滤器:中间件 http://laravelacademy.org/post/7812.html 简介 中间件为过滤进入应用的 ...
- [ Laravel 5.5 文档 ] 快速入门 —— 目录结构篇
简介 Laravel 默认的目录结构试图为不管是大型应用还是小型应用提供一个良好的起点.当然,你也可以按照自己的喜好重新组织应用的目录结构,因为 Laravel 对于指定类在何处被加载没有任何限制 — ...
- Laravel 5.5 文档 ] 快速入门 —— 安装配置篇
服务器要求 Laravel 框架对PHP版本和扩展有一定要求,不过这些要求 Laravel Homestead 都已经满足了,不过如果你没有使用 Homestead 的话(那真是一件很遗憾的事情),有 ...
- [ Laravel 5.5 文档 ] 底层原理 —— 一次 Laravel 请求的生命周期
Posted on 2018年3月5日 by 学院君 简介 当我们使用现实世界中的任何工具时,如果理解了该工具的工作原理,那么用起来就会得心应手,应用开发也是如此.当你理解了开发工具如何工作,用起 ...
- Elasticsearch之文档的增删改查以及ik分词器
文档的增删改查 增加文档 使用elasticsearch-head查看 修改文档 使用elasticsearch-head查看 删除文档 使用elasticsearch-head查看 查看文档的三种方 ...
- [ Laravel 5.3 文档 ] 安全 ―― API认证(Passport)保障安全性。
1.简介 Laravel通过传统的登录表单已经让用户认证变得很简单,但是API怎么办?API通常使用token进行认证并且在请求之间不维护session状态.Laravel使用LaravelPassp ...
随机推荐
- uC/OS-II汇编代码
;*************************************************************************************************** ...
- 纯css3实现旋转的太极图
效果图: 代码如下: <!DOCTYPE html> <html> <head lang="zh"> <meta charset=&quo ...
- c++异常捕获
概念: “C++异常”就是 try{}catch(...){} “SEH异常”就是 __try{} __except(-//){} (关于这两种异常,如有不了解的地方,网上有很多资料可以参考) 目前微 ...
- TCP/UDP端口列表
http://zh.wikipedia.org/wiki/TCP/UDP%E7%AB%AF%E5%8F%A3%E5%88%97%E8%A1%A8 TCP/UDP端口列表 本条目可通过翻译外语维 ...
- Java web 使用页面压缩
借助类,相关依赖: <!-- https://mvnrepository.com/artifact/net.sourceforge.pjl-comp-filter/pjl-comp-filter ...
- docker快速搭建wordpress(centos7)
docker pull tutum/wordpress #拉取镜像 docker run -d -p 80:80 tutum/wordpress #运行容器 使用服务器IP访问即可
- 北斗/GPS
北斗/GPS都是用的nmea通用协议. NMEA-0183协议定义的语句非常多,但是常用的或者说兼容性最广的语句只有$GPGGA.$GPGSA.$GPGSV.$GPRMC.$GPVTG.$GPGLL等 ...
- Jbuilder 2008安装及破解
1.下载Jbuilder及破解包 2.安装: 1>点击install 2> 选择第一项: 3>同意协议: 4>选择安装目录 5>选择服务器 6>选择默认 7> ...
- RL中“#” “?” &“”号的作用
阅读目录 1. # 2. ? 3. & 回到顶部 1. # 10年9月,twitter改版.一个显著变化,就是URL加入了"#!"符号.比如,改版前的用户主页网址为http ...
- rz和sz上传下载文件工具lrzsz
######################### rz和sz上传下载文件工具lrzsz ####################################################### ...