laravel5.2的新功能

原创
2016/11/16 04:55
阅读数 132

上一节课我们学了laravel5.3的新特性 https://my.oschina.net/lilugirl2005/blog/787478

这节课主要讲一些laravel5.2的新特性在laravel5.3的基础上演示

我们还是以10yue.live网站为例 

laravel5.2的新功能

路由模型绑定

实例:routes/web.php页面中添加路由

Route::get('/user/{user}',function(\App\User $user){
   return $user;
});

Route::get('/post/{post}',function(\App\Post $post){
   return $post;
});

访问  https://10yue.live/post/3  或者 https://10yue.live/user/4 测试

那如果我想通过用户表的username字段访问用户信息改如何做呢?

做到这点请确保username是不重复的值

首先我需要在user表里增加一个username的字段

修改/database/migrations的用户表文件  增加username字段

相应的修改/database/factories/ModelFactory.php文件 $faker->userName可以生成不重复的假用户名

清空数据库 重新执行数据结构生成命令  php artisan migrate:refresh

(如果是生产环境的数据,请勿执行,因为所有数据会被清空)

执行tinker命令生成10条用户数据

修改app/Providers/RouteServiceProvider.php文件 添加如下代码

且routes/web.php代码改为

在数据库中随便查找一个username

在浏览器键入地址https://10yue.live/user/alarkin  测试成功!

访问次数限制

举例 修改routes/web.php 的post路由 为其添加middleware 这个设置默认限制路由访问次数一分钟不超过60次

我们可以用httpie这个工具模拟http请求 ,首先要下载安装httpie

mac下安装httpie的命令是 brew install httpie

安装成功后在本地mac机器上敲入http命令 访问http://10yue.live/post/1看看

通过审查元素我们也可以分析到这个页面的头部信息

刷新页面会看到 X-RateLimit-Remaining的值一直在变

修改routes/web.php 的post路由 将一分钟的访问次数限制改为3

在浏览器上刷新三次页面http://10yue.live/post/1 会发现页面显示To Many Attempts

访问限制源码解读

观察 app/Http/Kernal.php文件

按图索骥观察 vendor/laravel/framework/src/Illuminate/Routing/Middleware/ThrottleRequests.php文件

这里的key是根据客户端请求的ip,方式,域名等信息加密后形成一个唯一值

两分钟实现注册登录

只要简单的执行 php artisan make:auth 即可,如果之前没有migrate 数据库,需要先migrate一下

 

然后你会发现resources/views文件夹下生成了一些试图文件夹和文件

同时在app/Http/Controllers文件夹下页生成了一些文件包和文件

观察代码 app/Http/Controllers/HomeController.php  

红色区域的代码表明 home路径下的页面需要登录才能访问

在浏览器中浏览页面https://10yue.live/home 会看到页面跳转到登录页面 

进入注册页面 https://10yue.live/register 注册一个账户尝试登录看看

登录后的样子

尝试使用忘记密码功能发送邮件,根据上一节课的配置 ,邮件将发送到mailtrap.io账号里

登录mailtrap.io看看 果然发现了邮件

点击重置密码按钮 尝试一下修改密码

这时候如果尝试将邮件发送到log中,只要修改一下.env配置 将MAIL_DRIVER改为log 

重启服务器 再次发送忘记密码请求

则可以在/storage/logs/larave.log  网站日志中看到邮件内容 (当然日志文件中还记录的所有的其他的日志内容)

laravel还自带了用户访问限制功能,如果一个用户连续错密码超过5次,系统将暂时拒绝该用户登录

最后 我们输入php artisan route:list命令 会看到系统自动生成了一些路由

然后查看代码auth的路由定义代码  vendor/laravel/framework/src/Illuminate//Routing/Router.php

全局变量errors

在首页试图 resources/views/welcome.blade.php文件中添加代码 {{dd($errors)}} 可以通过变量$errors获取全局的错误信息

多表认证登录

执行下面的命令生成admin表

php artisan make:migration create_admin_table --create=admin

修改admin表的migration文件  database/migrations/2016_12_01_061057_create_admin_table.php

添加如下字段

执行生成表命令 

php artisan migrate

复制Http/Controllers/Auth文件夹 重命名为AdminAuth

修改Http/Controllers/AdminAuth下的所有文件的命名空间为

namespace App\Http\Controllers\AdminAuth;

修改Http/Controllers/AdminAuth/LoginController.php文件的redirectto属性为 /admin 

增加属性guard 值为admin

  protected $redirectTo = '/admin';
  protected $guard='admin';   //与表名一致

且删除红框部分的代码

添加两个新方法 

  public function showLoginForm(){
      return view('admin.auth.login');
    }

 

用同样的方式修改 Http/Controllers/AdminAuth/RegisterController.php

namespace App\Http\Controllers\AdminAuth;

use App\Admin;
use Validator;
use App\Http\Controllers\Controller;
use Illuminate\Foundation\Auth\RegistersUsers;

class RegisterController extends Controller
{
    /*
    |--------------------------------------------------------------------------
    | Register Controller
    |--------------------------------------------------------------------------
    |
    | This controller handles the registration of new users as well as their
    | validation and creation. By default this controller uses a trait to
    | provide this functionality without requiring any additional code.
    |
    */

    use RegistersUsers;

    /**
     * Where to redirect users after login / registration.
     *
     * @var string
     */
    protected $redirectTo = '/admin';
    protected $guard='admin';   //与表名一致

    public function showRegistrationForm(){
      return view('admin.auth.register');
    }

    /**
     * Get a validator for an incoming registration request.
     *
     * @param  array  $data
     * @return \Illuminate\Contracts\Validation\Validator
     */
    protected function validator(array $data)
    {
        return Validator::make($data, [
            'name' => 'required|max:255',
            'email' => 'required|email|max:255|unique:users',
            'password' => 'required|min:6|confirmed',
        ]);
    }

    /**
     * Create a new user instance after a valid registration.
     *
     * @param  array  $data
     * @return User
     */
    protected function create(array $data)
    {
        return Admin::create([
            'name' => $data['name'],
            'email' => $data['email'],
            'password' => bcrypt($data['password']),
        ]);
    }
}

 

在resources/views文件夹下创建admin文件夹 ,将resources/views/auth复制一份到resources/views/admin文件夹 ,修改一些明显的链接地址

 

在routes/web.php中添加路由

Route::get('/admin/login',  'AdminAuth\LoginController@showLoginForm');
Route::post('/admin/login','AdminAuth\LoginController@login');
Route::get('/admin/logout',  'AdminAuth\LoginController@logout');

Route::get('admin/register', 'AdminAuth\RegisterController@showRegistrationForm');
Route::post('admin/register','AdminAuth\RegisterController@register');

Route::get('/admin','AdminController@index');

通过命令生成AdminCntroller文件

php artisan make:controller AdminController

为app/Http/Controller/AdminController.php文件添加一个简单的index方法

  public function index(){
      return 'admin page';
    }

用命令生成Admin的model文件

php artisan make:model Admin

编辑这个model文件 app/Admin.php 

修改config/auth.php 文件 ,添加红框中的代码

 

用命令为admin生成一个middleware 

php artisan make:middleware RedirectIfNotAdmin

修改这个新生成的middleware文件 app/Http/Middleware/RedirectIfNotAdmin.php

修改app/Http/Kernel.php文件

然后就可以在app/Http/Controller/AdminController.php文件中使用这个middleware了

 

队列

先设置队列的驱动 修改配置文件.env 

执行命令 创建队列表

 php artisan queue:table
php artisan migrate

执行命令 创建一个job

php artisan make:job SendReminderEmail

在app/Jobs文件夹下会生成一个 SendReminderEmail.php文件

修改app/Jobs/SendReminderEmail.php


namespace App\Jobs;

use Illuminate\Bus\Queueable;
use Illuminate\Queue\SerializesModels;
use Illuminate\Queue\InteractsWithQueue;
use Illuminate\Contracts\Queue\ShouldQueue;

class SendReminderEmail implements ShouldQueue
{
    use InteractsWithQueue, Queueable, SerializesModels;


    public $user;

    /**
     * Create a new job instance.
     *
     * @return void
     */
    public function __construct(User $user)
    {
        $this->user=$user;
    }

    /**
     * Execute the job.
     *
     * @return void
     */
    public function handle()
    {
        \Log::info('send remind email to'.$this->user->email);
    }
}

新增一个controller 

php artisan make:controller UsersController

为app/Http/Controllers/UsersController.php 添加store方法

  public function store(){
      $users=\App\User::where('id','>',5)->get();

      foreach($users as $user){
        $this->dispatch(new \App\Jobs\SendReminderEmail($user));
      }

      return 'Done';
    }

在routes/web.php 添加路由

Route::get('job','UsersController@store');

在浏览器中执行 https://10yue.live/job

然后数据库生成了对应的任务列表

执行命令 php artisan queue:work 就可以执行队列中的任务

任务执行后会在日志文件storage/logs/laravel.log中留下记录 

 

使用 Beanstalkd 实现队列

先要在服务器上安装beanstalkd 执行命令

 

展开阅读全文
打赏
0
0 收藏
分享
加载中
更多评论
打赏
0 评论
0 收藏
0
分享
返回顶部
顶部