- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
我正在为 REST Api 设置一个 Laravel 项目。基本上,我将用户分为两个表,User 和 Admin(模型名称)。我想使用默认 Laravel 的身份验证支架通过 Web 防护对管理员进行身份验证,并使用 JWT(tymondesigns 提供的软件包)通过 api 防护对用户进行身份验证。一切顺利。我配置了程序包,在 app/auth.php 中设置了守卫和提供程序,并且几乎可以正常工作。
我现在可以通过 Auth Scaffold 注册管理员,并通过用户的自定义登录 Controller 登录用户。我在浏览器上测试了管理员登录,它工作正常。然后在为用户设置登录之前,我将 app/auth.php 中的默认保护更改为 api(是:web)认为这是有道理的,因为大多数请求将作为 API 完成。我继续构建自定义登录 Controller 并测试了自定义登录。路由保存在不同的文件中,API 路由在 routes/api.php 和管理路由 routes/web.php。我再次在浏览器上测试管理员登录,但它不再起作用了。再次尝试将默认守卫更改为 web,它正在运行。不知何故,为每条路线定义的守卫被忽略,只使用默认守卫。我在网上阅读了很多内容,但我尝试过的所有方法都没有用。
文件如下:
配置/auth.php
'defaults' => [
'guard' => 'api',
'passwords' => 'users',
],
'guards' => [
'web' => [
'driver' => 'session',
'provider' => 'admins',
],
'api' => [
'driver' => 'jwt',
'provider' => 'users',
],
],
'providers' => [
'users' => [
'driver' => 'eloquent',
'model' => App\User::class,
],
'admins' => [
'driver' => 'eloquent',
'model' => App\Admin::class,
]
],
'passwords' => [
'users' => [
'provider' => 'users',
'table' => 'password_resets',
'expire' => 60,
],
'admins' => [
'provider' => 'admins',
'table' => 'password_resets',
'expire' => 60,
]
],
路由/web.php
Route::get('/', function () {
return view('welcome');
});
Auth::routes();
Route::get('home', 'HomeController@index')->name('home');
路由/api.php
Route::middleware('guest')->post('login', 'UserAuth\LoginController@login')->name('user.login');
Route::middleware('auth')->get('user', 'BaseController@loggedUserAPI')
->name('user.user');
感谢任何形式的帮助或建议。
最佳答案
正如您所说,您使用的是 Laravel 提供的默认身份验证脚手架,您必须覆盖 Http/Controllers/Auth/LoginController 中的 guard() 方法,否则将始终使用默认保护。
/**
* Get the guard to be used during authentication.
*
* @return \Illuminate\Contracts\Auth\StatefulGuard
*/
protected function guard()
{
// specify the guard that should be used for login attempts
return Auth::guard('web');
}
您还应该修改 LoginController 的构造函数以使用正确的中间件:
public function __construct()
{
$this->middleware('guest:web')->except('logout');
}
在你的 routes/web.php 文件中,你必须告诉你的 auth 和 guest 中间件使用正确的守卫(如果它不是默认的)
//例如:
Route::middleware('auth:web')->get('admin', 'AdminController@dashboard')
->name('user.user');
关于php - 非默认守卫在 Laravel 5.5 中被忽略,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/46816799/
我如何使用 if 守卫的理解? type Error = String type Success = String def csrfValidation(session:Session,
我试图深入理解 Angular,所以我阅读了 the docs这非常有帮助。 现在我正在研究守卫。我在文档中阅读了此声明。 The router checks the CanDeactivate an
是否可以批量guard's 观看通知? 例如,如果移动了一个子文件夹,watch 会为每个文件发出一个事件。我真正想要的是一个通知,而不是几个,如果有什么变化。 最佳答案 虽然这不是批量更改,因此没有
我正在使用 Guard gem 在开发的某些时候,我只需要跟踪一个特定的文件或几个文件,而不是整个项目。 是否有一些方便的方法来临时跟踪特定文件? 我知道这可以通过修改保护文件来完成,但我认为这不是一
已解决 真正帮助我的是我可以#include .cpp 文件中的 header 而不会导致重新定义的错误。 我是 C++ 新手,但我有一些 C# 和 Java 编程经验,所以我可能会遗漏一些 C++
是否有可能保证在范围退出时完成的变量。 具体来说,我想要一个守卫:在初始化时调用特定函数,并在作用域退出时调用另一个特定函数的东西。 最佳答案 这最好明确地完成: class Guard def
我有一个类型代表我的应用程序的游戏状态,对于这个问题假装它很简单,例如: Game { points :: Int } 我用 State monad 定义我的游戏逻辑。 type GameState
这个问题在这里已经有了答案: Why is GHC complaining about non-exhaustive patterns? (3 个答案) 关闭 7 个月前。 我有以下代码,它定义了一
我知道在头文件中使用 include guards 是为了防止某些东西被定义两次。不过,使用此代码示例完全没问题: foo.c #include #include #include "bar.h"
这个问题在这里已经有了答案: Why is GHC complaining about non-exhaustive patterns? (3 个答案) 关闭 7 个月前。 我有以下代码,它定义了一
我知道 guard 在 Swift 中的作用。我已经阅读了有关使用 guard 或 if let 的问题。但是,guard (condition) else { return } 和if !condi
我正在试验 Xcode 提供的不同分析选项,但是当我在 Diagnostics 选项卡中启用 Guard Malloc 选项并尝试运行时,我收到了这个错误立即崩溃: dyld: could not l
这是我的 canDeactivate 守卫,它可以工作。但是我不想在使用提交按钮时调用守卫。只有当我通过任何其他方式导航时。怎么办? import { Injectable } from '@angu
嗨,这让我发疯。找了半天也没找到解决方法。 如何为 Guardfile 中的所有守卫触发“run_all”。 当我在 shell 中运行“guard”时,我希望它假装所有文件都已更改并触发所有守卫。
我想知道是否有守卫(断言)函数的 golang 命名约定?我用谷歌搜索了一下,但找不到任何确定的东西。我在“The Go Programming Language”一书中读到,使用“必须”前缀是一种常
我正在尝试使用 guard 的 --listen-on带有 vagrant 的选项,如概述 here ,但我无法让它工作。 如果我添加 config.vm.network :forwarded_por
我目前有一个路线守卫,例如 export class EntityGuard implements CanActivate { constructor(private readonly route
我正尝试在 less 中创建一个高度可定制的按钮 mixin。例如,我希望客户能够进入他们的 .less 文件并写入: .my-button { .btn(@bg: #FFF, @font:
这个问题在这里已经有了答案: #pragma once vs include guards? [duplicate] (13 个答案) 关闭 3 年前。 我正在浏览 Implementation d
这个问题在这里已经有了答案: Is #pragma once a safe include guard? (15 个答案) 关闭 3 年前。 我正在开发一个已知只能在 Windows 上运行并在 V
我是一名优秀的程序员,十分优秀!