laravel 5.2 前后端用户认证方案

   2016-12-23 0
核心提示:laravel 5.2 中自带的用户认证服务可以说是很好的一项服务,开箱执行个 php artisan make:auth 命令,改下视图就可以实现网站用户登录,注册功能了;真是轻松便捷。 那么问题来了:如何前后端分离认证?如果表结构与laravel开箱的 users 表结构不一样呢,该怎

laravel 5.2 中自带的用户认证服务可以说是很好的一项服务,开箱执行个 php artisan make:auth 命令,改下视图就可以实现网站用户登录,注册功能了;真是轻松便捷。

那么问题来了:

  • 如何前后端分离认证?

  • 如果表结构与laravel开箱的 users 表结构不一样呢,该怎么样?

其实上面的问题在laravel学院文档 手动认证用户 已经有说明了,只是例子比较少所以初学者有点难理解;因为最近看了auth部分源码,所以这里写篇文章解决下这些问题。

Auth方法

首先 laravel auth 用户认证都是通过 Auth门面 实现的,需要了解的可以自行查看源码;

那么解决上面问题的方法是什么呢?

那就是手动认证用户?

手动认证可以使用 Auth::attempt 或者 Auth::login 方法。

Auth::attempt :

Auth::guard('看守')->attempt($credentials);//尝试认证一个用户,返回bool值

Auth::guard('看守') 是设置看守。

看守的意思就类似于门口的门卫,当然如果不设置的话laravel默认会使用 web 看守。

$credentials 是请求的数据,类似于:

$credentials = [
    'name' => 'test',
    'password' => '123456',
];

Auth::login

Auth::guard('看守')->login($model);//认证$model实例,没有返回值

$model是一个模型数据

admin认证例子

有了上面连个方法就可以做用户认证操作了。

创建数据表

创建模型 Admin :

php artisan make:model Admin -m

-m 参数表示生成数据库迁移

命令会在 database/migrations 目录生成迁移 2016_12_06_120056_create_admins_table.php ,并在 app 目录生成模型文件 Admin.php

编写迁移 2016_12_06_120056_create_admins_table.php 中up方法:

public function up()
{
    Schema::create('admins', function (Blueprint $table) {
        $table->increments('id');
        $table->string('name',15)->unique();
        $table->string('password');
        $table->rememberToken();
        $table->timestamps();
    });
}

编写模型 Admin.php 信息:

<?php

namespace App;
//use Illuminate\Database\Eloquent\Model;
use Illuminate\Foundation\Auth\User as Authenticatable;
//class Admin extends Model
//采用Auth::attempt接口认证用户,用户模型必须继承Authenticatable
class Admin extends Authenticatable
{
     protected $fillable = [
        'name', 'password',
    ];

    /**
     * The attributes that should be hidden for arrays.
     *
     * @var array
     */
    protected $hidden = [
        'password', 'remember_token',
    ];
}

这里值得注意的是 Admin 模型集成的是 Authenticatable ,应为 Auth 门面的原因。

执行迁移创建数据表:

php artisan migrate

定义看守

定义看守需要在 config/auth.php 文件中定义;

guards 中增加 admin 看守:

//定义看守
'guards' => [
    'web' => [
        'driver' => 'session',
        'provider' => 'users',
    ],
    'admin' => [
        'driver' => 'session',
        'provider' => 'admins',
    ],
    'api' => [
        'driver' => 'token',
        'provider' => 'users',
    ],
],

声明 admins 提供者:

//声明提供者
'providers' => [
    'users' => [
        'driver' => 'eloquent',//eloquent or database
        'model' => App\User::class,
    ],
    'admins' => [
        'driver' => 'eloquent',//eloquent or database
        'model' => App\Admin::class,
    ],
],

保存文件。

编写路由和测试代码

为了方便,这里就不再建立视图了,直接在 routes.php 调试。

routes.php 文件编写代码:

Route::get('admin/register',function(){
    $admin = Admin::create([
        'name' => 'test5',
        'password' => bcrypt('123456'),
    ]);
    Auth::guard('admin')->login($admin);
    return redirect('admin/success');
});
Route::get('admin/login',function(){
    $credentials = [
        'name' => 'test1',
        'password' => '123456',
    ];
    $bool = Auth::guard('admin')->attempt($credentials);

    if($bool){
        return redirect('admin/success');
    }else{
        dump('登录失败');
    }
});
Route::get('admin/success',function(){
    dump(Auth::guard('admin')->user());
    dump(session()->all());
});
Route::get('admin/logout',function(){
    Auth::guard('admin')->logout();
    dump(Auth::guard('admin')->user());
    dump(session()->all());
});
  • admin/register 注册

  • admin/login 登录

  • admin/success 登录、注册成功跳转

  • admin/logout 注销

访问 admin/register 注册:

laravel 5.2 前后端用户认证方案

注册并登录成功。

访问 admin/login 登录:

laravel 5.2 前后端用户认证方案

访问 admin/logout 注销:

laravel 5.2 前后端用户认证方案

总结

如果你的表结构与laravel默认的users表结构一样,那么用户认证是很容易的。

如果表结构与laravel默认的 users 表结构不一样,那么你就需要采用 Auth 门面的方法自己重新编写控制器;当然你也可以完全丢掉 Auth 门面,自己实现过程。

最后说一句

如果还有不懂的朋友可以评论区问,我基本每天来,我尽力解答。

 
标签: Laravel
反对 0举报 0 评论 0
 

免责声明:本文仅代表作者个人观点,与乐学笔记(本网)无关。其原创性以及文中陈述文字和内容未经本站证实,对本文以及其中全部或者部分内容、文字的真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
    本网站有部分内容均转载自其它媒体,转载目的在于传递更多信息,并不代表本网赞同其观点和对其真实性负责,若因作品内容、知识产权、版权和其他问题,请及时提供相关证明等材料并与我们留言联系,本网站将在规定时间内给予删除等相关处理.

  • nginx 各类网站设置 (laravel , thinkphp , nod
    基础部分设置[root@centos ~]# vim /opt/nginx/conf/nginx.confuser www www;worker_processes auto;pid logs/nginx.pid;worker_rlimit_nofile 100000;events {use epoll;multi_accept on;worker_connections 65535 ;}http {include mime.types;default_type
    02-09
  • PHP trait 特性在 Laravel 中的使用个人心得
    trait 是在PHP5.4中为了方便代码复用的一种实现方式,但目前我在看的的PHP项目中较少看的有程序员去主动使用这个实现方式,在laravel中有很多 trait 的使用,关于trait 在 laravel 的使用请参看 Laravel 在哪些地方用了 trait?我曾在 Laravel 中大型项目面向
    02-09
  • 让我们用 laravel-mix 为 TypeScript 和 Sass
    介绍前端编译TypeScript、Sass、模板引擎等时经常用到Gulp和webpack。这是我个人的印象,但它们似乎都难以管理,因为它们的描述往往复杂而冗长。我不想积极进行,因为我要担心加载器的顺序并且有很多配置选项,我必须花时间去了解它们。我想推荐那里laravel
  • PHP Laravel软删除的实现方法介绍
    用Laravel 自带的 Eloquent ORM 来实现软删除。首先在数据迁移文件中添加删除时间字段./database/migrations/2014_10_12_000000_create_users_table.php?phpuse Illuminate\Database\Migrations\Migration;use Illuminate\Database\Schema\Blueprint;use Illu
  • Laravel中如何使用PHP的装饰器模式 php laravel
    本文小编为大家详细介绍“Laravel中如何使用PHP的装饰器模式”,内容详细,步骤清晰,细节处理妥当,希望这篇“Laravel中如何使用PHP的装饰器模式”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。装饰器模式定义:它可以帮助您在
    02-08 laravelphp
  • PHP laravel使用自定义邮件类实现发送邮件
    PHP laravel使用自定义邮件类实现发送邮件
    当登录邮箱为腾讯企业邮箱的时候。Phpmailer发送邮件就不好用了,具体哪里不好用,我没真没找到。但是,邮件得发啊,怎么办呢?我这里搞了一个自定义的发送邮件类,腾讯企业邮箱也可用。但是,邮件发送失败,不会返回报错信息,这个可能是有点坑。源码如下:?
  • 详解PHP laravel中的加密与解密函数
    目录一:简介二:配置三:使用加密/解密1:加密2:不使用序列化进行加密3:解密Laravel为我们提供了完整的加密方法及加密模式。我之前一般在加密的时候使用的是我自己写的加密函数,但是这个玩意,有的位置还是不太使用,当然,破解的话,基本上也是不可能的
  • PHP laravel缓存cache机制详解
    目录一、访问多个缓存存储二、从缓存中获取数据1.获取数据并设置默认值2.检查缓存项是否存在3.数值增加/减少4.获取存储5.获取删除三、缓存中存储数据1.获取存储数据2.缓存不存在时存储数据3.永久存储数据四、从缓存中移除数据Laravel中的cache为我们提供了三
  • PHP laravel实现导出PDF功能
    PHP laravel实现导出PDF功能
    目录一、laravel-tcpdf二、tcpdf三、TCPDF解决保存中文文件名的方法补充一、laravel-tcpdf导出PDF文件Laravel框架为我们集成了一个插件tcpdf。下载地址:https://github.com/elibyy/tcpdf-laravel然后使用composer进行安装就可以了。具体安装过程,请查看文末
  • PHP laravel缓存cache机制怎么实现
    今天小编给大家分享一下PHP laravel缓存cache机制怎么实现的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。Laravel中的cache为我们
点击排行