首页 > 解决方案 > 在 Laravel 中登录身份验证而不使用数据库

问题描述

我对 laravel 有点陌生,我需要设置一个用户/密码登录系统,但我不能使用默认数据库。是否可以将信息凭证存储在数据库之外?一个例子会是什么样子?

标签: phplaravelauthentication

解决方案


Laravel 的身份验证系统依赖于 Eloquent,因此依赖于数据库。使用Sushi,您可以使用 Array 作为数据库驱动程序。也许这将是一种适合您的方法。

另一个想法可能是使用Basic Authentication。您可以在您的网络服务器(Apache、Nginx 等)或 Laravel 中使用中间件进行设置。

这是这样一个中间件的样子。

namespace App\Http\Middleware;

use Closure;

class BasicAuthMiddleware
{
    /**
     * Handle an incoming request.
     *
     * @param  \Illuminate\Http\Request  $request
     * @param  \Closure  $next
     * @return mixed
     */
    public function handle($request, Closure $next)
    {
        $authenticationHasPassed = false;

        if ($request->header('PHP_AUTH_USER', null) && $request->header('PHP_AUTH_PW', null)) {
            $username = $request->header('PHP_AUTH_USER');
            $password = $request->header('PHP_AUTH_PW');

            if ($username === config('auth.basic_auth.username') && $password === config('auth.basic_auth.password')) {
                $authenticationHasPassed = true;
            }
        }

        if ($authenticationHasPassed === false) {
            return response()->make('Invalid credentials.', 401, ['WWW-Authenticate' => 'Basic']);
        }

        return $next($request);
    }
}

(这个代码示例来自我的一篇博客文章,我需要一个身份验证功能而不使用数据库)。

如果您想实现这一点,我建议您阅读有关中间件配置的文档。


推荐阅读