首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

Laravel 的优雅之处 之,Passport搭建SSO系统

今天我们就以 Laravel Passport 为例,搭建一个SSO系统。...对于 Laravel 的认证系统,可以通过使用 Laravel Passport 这个包来构建一个基于 OAuth2 的单点登录(SSO)系统。...下面是一些大致的步骤:首先,在 Laravel 项目中安装 Laravel Passport 包,并按照官方文档进行配置。接着,需要创建一个专门用于授权的 Passport 客户端。...auth()->user() : null;});接下来,我们需要创建一个路由来处理用户身份验证请求。可以使用 Laravel 自带的 AuthController 类来处理此请求。...假设我们有一个名为“App2”的应用程序,现在我们需要修改该应用程序的身份验证逻辑,以使用我们刚才创建的 Passport 客户端来进行身份验证。

1.2K50
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    laravel + passport + vue安装过程中遇到的麻烦

    1、 Conclusion: don't install laravel/ui v2.4.1 Conclusion: remove laravel/framework v6.18.40 laravel.../ui版本也是和laravel版本对应的,2.4不能给6.18安装 2、登录界面一直往vue前端界面跳转: 不是后端路由、控制器等的问题。...不修改vue首页的时候是不会出现‘跳登录、再加载前端’的问题的 关键是也加载了app.js文件。 也就是说这个登录界面已经是vuejs版本的登录界面了,甚至是vuejs的使用方式的一个优秀样例。...---- 样式(丑不丑)取决于css/app.css文件 app.js应该是vue.js在laravel里使用的时候,必须这样做的一个打包文件(囊括了普通vue项目的所有文件)吧!...NODE_ENV=development node_modules/webpack/bin/webpack.js --progress --hide-modules --config=node_modules/laravel-mix

    1.4K20

    Laravel 中如何更方便的修改 Passport Personal Access Token 过期时间

    认真看过 Laravel Passport 文档 的人应该知道,它的 Personal Access Token 是不支持自定义过期时间的,tokensExpireIn 对此类 token 无效,原文如下...默认时间为 1 年,但是这可能不满足我们的需求,我们想要改成其它更短的时间怎么办呢?...今天尝试了一下,应该算是全网可以找到的最简单方法了,直接在 app/Providers/AppServiceProvider 中添加一句就可以搞定,下面以改为有效期为 1 周的示例来演示: app/Providers...php //... use Laravel\Passport\Bridge\PersonalAccessGrant; use League\OAuth2\Server\AuthorizationServer...关于时间值的写法,请参考: https://secure.php.net/manual/en/dateinterval.construct.php

    2.5K10

    Laravel 多态关系的表单验证

    相信大家使用 Laravel 开发应用的时候都会有评论模块吧,而且我们通常将该模块设计为多态关系(如果你对这个关系还不明白的话,请赶紧打开 Laravel 文档数据库关系章节复习一遍吧!)。..., ]); 其实不管哪一种,我们都少不了表单验证,而且无论使用任何一种我们都得需要传入两个关键参数: 类型与 id,那就涉及到一个问题,如何验证呢?...那么我们现在介绍一种拓展验证规则的写法: 首先我们在 AppServiceProvider 中注册一个验证规则 poly_exists: Validator::extend('poly_exists',...是不是简单很多,而且这样验证规则还能重用在其它同类多态关系的地方哦。 这样就结束了么?没有! 我们上面的拓展验证规则的写法没有感觉有些粗暴么?是时候规范一下了。...   } } public function boot() {    $this->registerValidators(); } 在 boot 方法中我们统一注册了 $validators里的验证规则

    2.2K40

    Laravel API 开发推荐阅读清单

    社区优秀文章 Laravel 5.5+passport 放弃 dingo 开发 API 实战,让 API 开发更省心 - 自造车轮。...讲讲我最近用 Laravel 做的一个 App 后端项目 Laravel Passport API 认证使用小结 关于 RESTful API 设计的总结 Laravel 5.5 使用 Passport...RESTful API 的一些心得 对 REST 的理解 用 Laravel 搭建带 OAuth2 验证的 RESTful 服务 在 Laravel 中动态隐藏 API 字段 Nginx 下部署...decision-graph.svg 一张大图展示整个 REST API 的验证过程,及各种状态码出现的时机 现成 API 例子 Github API v3 被很多人参考和引用,比如对分页的处理方法、...,角色列表; 资源推荐接口、活跃用户接口; 接口本地化处理; API 接口错误代码机制; APNS 消息推送服务器端介绍及实现; API 测试 —— 单元测试、集成测试、黑盒测试; 快速完成 API 文档

    4.3K70

    Laravel 参数验证的疑与惑

    验证器怎么创建的,谁创建的 Laravel 文档调用验证器,除了通过控制器,还有就是通过Facades的方式创建验证器对象。...Laravel本身提供了很多通用的参数验证规则,但是对于一些特定的场景,还是需要提供验证规则的扩展。...Laravel验证规则的扩展有两种方式。...1 通过extend方法扩展 //这是一个简单的参数比较的验证规则,Laravel5.8中提供,Laravel5.5中未提供 //验证规则如下: 'max_num'=>'gte:min', Validator...总结 通过以上源码的学习,可以看出Laravel验证器的创建都是用过验证器工厂类创建的。如果需要自定义验证器,可以通过修改验证器工厂类,或者设置验证器工厂类的resolver属性接管验证器的实例化。

    3.4K00

    Laravel 6.13.0 版本发布,允许对隐式属性验证消息进行格式化

    Laravel 开发团队本周发布了 v6.13.0 版本,支持对隐式验证属性错误消息进行格式化,并且新增了一个 ensureDirectoryExists() 文件系统方法。...下面我们一起来看看一些重要的新特性: 1、重要特性 1)允许格式化隐式属性验证消息 从 Laravel 6.13.0 开始,支持在验证器中为隐式属性配置自定义错误消息格式: // 将 "0.age must.../CHANGELOG-6.x.md#v6130-2020-01-28,以及 6.12.0 和 6.13.0 的版本差异:https://github.com/laravel/framework/compare...2、更新日志 1)新增特性 新增 --api 选项到 make:model 命令 新增 PendingResourceRegistration::shallow() 方法 允许使用闭包格式化隐式属性验证消息...广播时的频道名称问题 在验证之前替换星号 3)代码调整 在新的队列工作者循环中重置超时处理器 声明:本文翻译整理自 Laravel News。

    75720

    Laravel 5.5 的自定义验证对象类

    Laravel 5.5 将提供一个全新的自定义验证规则的对象,以作为原来的 Validator::extend 方法的替代。...Laravel 中的表单验证是比较方便的,而且内置了大量的可用验证规则,但不管官方提供了多少,总还是会有满足不了需求的时候。...但在 Laravel 5.5 版本中,我们有了新的手段,只要定义一个实现 Illuminate\Contracts\Validation\Rule 接口的类即可实现自定义的验证规则,并可以直接使用。...ImplicitRule { ... } 采用 Laravel 5.5 新增的自定义验证类,可以更好地管理大量的自定义验证规则,而且在 PHPStorm 之类的 IDE 中,从验证代码里快速跳转到对应的验证类的代码也会更方便...你可以查看该功能在 Laravel 框架的 github 上的 Pull Request,阅读具体的实现代码以及相关的测试代码。

    3K90

    Laravel中优雅的验证日期需要大于今天

    request并注入到需要验证控制器的方法 Laravel 下图圈出的红色部分,需改成return true因为我们身份验证一般不在这里验证 Laravel 如上图,end_date...正确的方法是这样的 Laravel 重写父类的prepareForValidation方法,之后再测试 Laravel 这时候得到想要的验证了 分析一下过程 能通过依赖注入实例化我们想要的对象...里有关表单验证的服务提供者 Laravel Laravel Laravel 我们可以看到当实现ValidatesWhenResolved对象的类在解析之后会自动调用...Laravel 这个类找到了答案,在validate方法里分三步主要的 $this->prepareForValidation() 在验证之前的准备 新建一个验证实例 开始验证 之所以是需要在验证之前设置...curr_date,我们来看看新建验证实例便知道答案 Laravel Laravel 这里有一个地方导致我们的问题出现,就是先调用了$this->validationData

    31010

    钉钉消息已读、未读咋实现的嘞?

    前言 一款app,消息页面有:钱包通知、最近访客等各种通知类别,每个类别可能有新的通知消息,实现已读、未读功能,包括多少个未读,这个是怎么实现的呢?...所有,判断有没有小红点,或者小红点的数字是多少,就是简单的获取你与虚拟人的对话的未读的消息的数量。...当然,一个动作不一定只发一条消息,比如,图中下方有个金刚键"消息",它是所有消息的总和,所以,投递其他消息的时候,也要给它投递一次,不过它只展示一个未读数字,所以这个消息只需要一个msg_id即可,不需要消息...实际上,图中的需求,比如“设置”,"隐私设置",是整个产品全局的,所以可以弄个简单的"广播消息模式",广播模式就是维持一个单向的消息的队列,所有的人都可以拉取这个队列的消息,只需要他们各位维护自己的last_id..."已读和未读"。它包含两层意思,一个判否,即内容你是否读过,二是计数,即这个内容有多少人读过。 长尾原因 如果你用Redis存储,成本非常高,浪费非常严重。

    53410

    面试题:群聊消息的已读未读设计

    一朋友和我讨论他前段时间面试某大公司的一题目 : 企业IM比如企业微信、钉钉里面的群消息的有个已读未读的功能,发送者刚发出消息时,当前群里其他群成员都是未读状态,陆陆续续有人看了这个消息,这时候消息的详情变成...x人已读,y人未读,如下图所示,有具体的已读未读列表(万恶的功能,看到同事or老板的消息不能假装没看到了),每条消息对应一个唯一的messageid(uint64_t),每个用户对应一个唯一的userid...(uint64_t),应该如何保存这个消息对应的已读未读详情呢?...仔细分析,按照目前的设计,每一条消息,已读未读详情就要占用8B * 群成员数的内存,如果一个活跃的200人大群,每发一条消息,已读未读就要1600B,如果平均每天消息量是1k,那每个这样的群,每天就要1.6MB...比如C退出群,发消息时maxid还是5,已读+未读总人数应该是3(不包括发消息者本人),目前信息只有5个bit(0/1),识别不出来谁已经退出群聊了 2、退出群聊的成员如何处理?

    2K41

    3分钟短文 | Laravel 表单验证数组的数据

    引言 本文说一个小的知识点,在表单验证中,对数组数据进行验证, 我们需要进行两项,一项是数组本身的验证,一项是数组元素的验证。 ?...明确了需求,我们发现上述的验证,laravel内置的规则基本可以解决。只是对于字段是数组,且数组长度满足某些条件的要求,有些苛刻。具体如何实现呢?...laravel表单验证规则中,使用星号,可以匹配数组的元素。...那么在laravel的验证器中,应该如何写呢? 这与指定了字段名的数组不同,这个数组的键是自动编排的数字,所以,我们需要通配键名。...写在最后 本文介绍了两种表单格式的数据的验证,一种是指定字段名的一维数组,一种是二维关联数组的验证, 如果有条件的大家可以看一下框架在这种处理验证规则的处理逻辑代码。

    3.6K10

    laravel5.4生成验证码的代码

    本篇博客介绍使用gregwar/captcha实现验证码的具体操作步骤,以及可能遇到的问题和解决办法。...操作步骤: 1.在laravel5.4项目根目录下找到 composer.json 这个文件, 添加 "gregwar/captcha": "dev-master" 和 "Gregwar\Captcha...然后打开命令行,找到项目的根目录,运行composer update, 可以看到这个扩展库已经下载好了, 3.接下来,就可以正常使用验证码了, 先定义路由: 接下来,介绍两种显示验证码的情况: 一、直接在网页上输出验证码图片...} } 然后在浏览器里访问之前定义好的路由,直接访问这个方法,就能看到输出的验证码了 第二种方法:在表单里显示验证码,把上面该文件路径写到标签的src属性中, 显示如下: 这里有两个问题需要注意...,照着下面的方法去直接输出验证码,你会发现验证码显示不出来,反而是一堆乱码, public function code($tmp) { //生成验证码图片的Builder对象,配置相应属性 $builder

    67820

    解决 laravel passport Key file %s permissions are not correct, should be 600 or 660 instead of %s

    laravel passport 问题描述 这是我之前遇到的问题,忘记记录了。...环境: laravel "5.3" dingo Api passport 我在做我自己的项目的时候,决定全部使用API风格,token鉴权的机制,这样就可以只写一份后端,而不考虑页面。...问题就出现在这,我是使用windows进行开发,当我安装完laravel/passport的时候,访问报错'Key file "%s" permissions are not correct, should...be 600 or 660 instead of 666',这显然是一个权限的问题,但是比较尴尬的是我在用windows,应该没涉及到什么权限的问题才对啊,毕竟windows的····(不能说坏话,万一我有一天去微软上班了呢...接着,我给laravel/passport提了一个issues, https://github.com/laravel/passport/issues/712 ,但是没人回复。

    18020
    领券