Laravel学习日记2018-07-05

2018-07-05  本文已影响0人  Purson

知识点

新建表

1.首先使用artisan建立迁移文件,这里再次加深迁移文件的理解,迁移文件就是定义数据表结构的,可以使用迁移文件定制、新建或删除表,比图形化方便、比命令行更方便,同时可以还原。这是Laravel的妙处!

$php artisan make:migration create_xxx_table --create="xxxx"

2.修改迁移文件,在up方法中加入Schema,注意对于数据量大,经常需要查询的字段建立索引。

3.执行命令迁移

$php artisan migrate

模型关系

如果没有一对多的关系,需要这样创建微博:

App\Models\Status::create()

一对多关联之后:

$user->statuses()->create()

以上是一种表面的优势,想深入一点,其实方便好多,以前搞关联需要在各自表格记录对应id或者新建一张表关联两者id,这里不用新建表。

填充测试数据

1.建立工厂

$php artisan make:factory xxxxFactory

2.内容填入 xxxFactory

3.创建Seeder编写填充要求

$php artisan make:seeder xxxxTableSeeder

3.在DatabaseSeeder中关联上面Seeder

 $this->call(StatusesTableSeeder::class);

4.启动填充

$php artisan migrate:refresh --seed

访问限制

1.Controller访问限制
访问某些Controller中需要先进行登录,只要在构造函数中加入auth中间件即可

public function __construct()
    {
        $this->middleware('auth');
    }

2.授权策略
1)新建策略

$ php artisan make:policy XXXPolicy

2)编写策略

public function destroy(User $user, Status $status)
    {
        return $user->id === $status->user_id;
    }

3)服务配置

 protected $policies = [
        'App\Model' => 'App\Policies\ModelPolicy',
        \App\Models\User::class  => \App\Policies\UserPolicy::class,
        \App\Models\Status::class  => \App\Policies\StatusPolicy::class,
    ];

  1. 使用策略
上一篇 下一篇

猜你喜欢

热点阅读