Laravel框架中的Possport Api的认证过程详解(图文)

发布时间 - 2018-08-04 00:00:00    点击率:

这篇文章给大家分享的内容是关于Laravel框架中的Possport  Api的认证过程详解(图文),内容很详细,有一定的参考价值,希望可以帮助到有需要的朋友。

1.laravel通过传统的登录表单已经让用户认证变得很简单,但是api怎么办?api通常使用token进行认证并且在请求之间不维护session状态。laravel使用laravel passport让api认证变得轻而易举,passport基于alex bilbie维护的league oauth2 server,可以在数分钟内为laravel应用提供完整的oauth2服务器实现。

2.安装

composer require laravel/passport

3.接下来,在配置文件 config/app.phpproviders 数组中注册 Passport 服务提供者:

 Laravel\Passport\PassportServiceProvider::class,

4.Passport 迁移将会为应用生成用于存放客户端和访问令牌的数据表 (迁移文件位置/vendor/laravel/passport/database)( 创建相关的表)

 php artisan migrate

5.创建生成安全访问令牌时用到的加密密钥及私人访问和密码访问客户端。

 php artisan passport:install

注意:到这里会有一个问题,就是当你注册完之后再一次代用注册接口是回报错,在从从新执行一下php artisan passport:install就OK了

6.Trait 添加到 App\User 模型中,这个 Trait 会给这个模型提供一些辅助函数,用于检查已认证用户的令牌和使用作用于。

Laravel\Passport\HasApiTokens

7.然后在 AuthServiceProviderboot 方法中添加 Passport::roues();

8.最后,修改文件 config/auth.phpapi 部分的授权保护项( driver )改为 passport 。此调整会让你的应用程序在接收到 API 的授权请求时使用 Passport 的 TokenGuard 来处理

9.增加测试路由api.php

Route::group(['namespace'=>'api'], function(){    
        // 无需认证路由    
        Route::match(['get','post'],'/login', 'UserController@login')->name('login');
        Route::post('/register', 'UserController@register');
        // 需认证路由    
        Route::group(['middleware' => 'auth:api'], function(){
        Route::get('/v1/passport', 'UserController@passport');
    });
    });

10.增加控制器

php artisan make:controller Api\UserController

content = array();
    }    
    public function login(){
        //dd(request('name'));
        if(Auth::attempt(['name' => request('name'), 'password' => request('password')])) {            
        $user = Auth::user();            
        $this->content['token'] =  $user->createToken(request('name'))->accessToken;            
        $status = 200;
        } else {            
        $this->content['error'] = "未授权";            
        $status = 401;
        }        
        return response()->json($this->content, $status);
    }    public function passport(){
        return response()->json(['user' => Auth::user()]);
    }    /**
     * 注册用户创建token
     */
    public function register(Request $request){
        $input = $request->all();        
        $validator = Validator::make($input, [
                    'email' => 'required|string|email|max:255|unique:users|min:4',            
                    'password' => 'required|string|min:6',
        ]);        
        if ($validator->fails())
         {            
            return response()->json(['error'=>$validator->errors()], 401);
        }        
        $input['password'] = bcrypt($input['password']);        
        $user = User::create($input);        
        if( $user !==false){            
        $success['token'] =  $user->createToken($input['name'])->accessToken;            
        $success['email'] =  $user->email;            
        $success['uid'] =  $user->id;            
        return response()->json(['error_code'=>0,'data'=>$success], 200);
        }        
        return response()->json(['error_code'=>1,'data'=>$input], 401);
    }
}

11.通过postman进行简单测试获取token  
注册:
接口地址:http://gems.com/api/register

登录:http://gems.com/api/login

测试获取用户信息:http://gems.com/api/v1/passport

相关文章推荐:

laravel框架模型model的创建与使用方法

laravel5.5框架中视图间如何共享数据?视图间共享数据的两种方法(附代码)


# php  # laravel  # postman  # Session  # Token  # register  # 接口  # database  # http  # 令牌  # 客户端  # 会有  # 两种  # 当你  # 有一定  # 相关文章  # 注册用户  # 给大家  # 很简单 


相关栏目: 【 网站优化151355 】 【 网络推广146373 】 【 网络技术251813 】 【 AI营销90571


相关推荐: 如何在新浪SAE免费搭建个人博客?  高端智能建站公司优选:品牌定制与SEO优化一站式服务  齐河建站公司:营销型网站建设与SEO优化双核驱动策略  Laravel如何实现本地化和多语言支持_Laravel多语言配置与翻译文件管理  Laravel如何优化应用性能?(缓存和优化命令)  北京网站制作费用多少,建立一个公司网站的费用.有哪些部分,分别要多少钱?  Android仿QQ列表左滑删除操作  Laravel怎么导出Excel文件_Laravel Excel插件使用教程  晋江文学城电脑版官网 晋江文学城网页版直接进入  Edge浏览器如何截图和滚动截图_微软Edge网页捕获功能使用教程【技巧】  如何在万网开始建站?分步指南解析  浅谈redis在项目中的应用  PHP 500报错的快速解决方法  原生JS获取元素集合的子元素宽度实例  5种Android数据存储方式汇总  Laravel策略(Policy)如何控制权限_Laravel Gates与Policies实现用户授权  如何快速启动建站代理加盟业务?  Laravel如何保护应用免受CSRF攻击?(原理和示例)  Laravel如何使用Facades(门面)及其工作原理_Laravel门面模式与底层机制  uc浏览器二维码扫描入口_uc浏览器扫码功能使用地址  米侠浏览器网页背景异常怎么办 米侠显示修复  打造顶配客厅影院,这份100寸电视推荐名单请查收  如何在Tomcat中配置并部署网站项目?  Laravel如何使用Passport实现OAuth2?(完整配置步骤)  Laravel如何创建自定义中间件?(Middleware代码示例)  Chrome浏览器标签页分组怎么用_谷歌浏览器整理标签页技巧【效率】  Javascript中的事件循环是如何工作的_如何利用Javascript事件循环优化异步代码?  图册素材网站设计制作软件,图册的导出方式有几种?  如何快速搭建个人网站并优化SEO?  Java类加载基本过程详细介绍  Laravel Octane如何提升性能_使用Laravel Octane加速你的应用  高防网站服务器:DDoS防御与BGP线路的AI智能防护方案  如何快速生成高效建站系统源代码?  如何快速选择适合个人网站的云服务器配置?  Python面向对象测试方法_mock解析【教程】  Android Socket接口实现即时通讯实例代码  网站页面设计需要考虑到这些问题  网站建设要注意的标准 促进网站用户好感度!  如何在景安服务器上快速搭建个人网站?  Laravel如何生成API文档?(Swagger/OpenAPI教程)  香港服务器网站测试全流程:性能评估、SEO加载与移动适配优化  如何解决hover在ie6中的兼容性问题  Laravel如何使用Seeder填充数据_Laravel模型工厂Factory批量生成测试数据【方法】  javascript和jQuery中的AJAX技术详解【包含AJAX各种跨域技术】  如何快速上传自定义模板至建站之星?  HTML5空格和margin有啥区别_空格与外边距的使用场景【说明】  Python结构化数据采集_字段抽取解析【教程】  瓜子二手车官方网站在线入口 瓜子二手车网页版官网通道入口  深圳网站制作的公司有哪些,dido官方网站?  标准网站视频模板制作软件,现在有哪个网站的视频编辑素材最齐全的,背景音乐、音效等?