>本文演示了使用Slim Micro-Framework和Cartalyst的Sentinel软件包构建一个简单的演示应用程序,以供用户授权。 Sentinel简化了用户管理,包括角色,权限和身份验证,在多用户应用程序中。
关键功能和好处:
>数据库设置:
>对于数据库交互,创建必要的表。 Laravel用户可以使用迁移:
composer require slim/slim:~2.0 twig/twig:~1.* cartalyst/sentinel:2.0.* illuminate/database illuminate/events symfony/http-foundation ircmaxell/password-compat
否则,在文件顶部添加数据库连接详细信息后,手动执行
。>应用程序引导(
):php artisan vendor:publish --provider="Cartalyst\Sentinel\Laravel\SentinelServiceProvider" php artisan migrate
vendor/cartalyst/sentinel/schema/mysql.sql
):public/index.php
<?php require_once __DIR__.'/../vendor/autoload.php'; $app = new \Slim\Slim(); //register bindings include_once __DIR__.'/../app/bootstrap/container.php'; include_once __DIR__.'/../app/routes.php'; $app->run();
>
app/bootstrap/container.php
创建角色:
定义角色和权限(此代码是临时的,运行一次以填充数据库):
$app->container->twigLoader = new Twig_Loader_Filesystem(__DIR__.'/../views'); $app->container->twig = new Twig_Environment($app->container->twigLoader, array( 'cache' => false, )); $capsule = new \Illuminate\Database\Capsule\Manager(); $capsule->addConnection([ 'driver' => 'mysql', 'host' => 'localhost', 'database' => 'capsule', 'username' => 'root', 'password' => 'root', 'charset' => 'utf8', 'collation' => 'utf8_unicode_ci', ]); $capsule->bootEloquent(); $app->container->sentinel = (new \Cartalyst\Sentinel\Native\Facades\Sentinel())->getSentinel();
文章的其余部分详细介绍了创建注册和登录页面,处理用户激活,实现权限检查(使用)以及登录用户。 代码示例涵盖路由,用户创建,角色分配,激活电子邮件发送以及基于许可的访问控制。 这篇文章以常见问题解答为例,解决了常见的前哨使用问题。
以上是消除使用Sentinel用户授权的痛苦的详细内容。更多信息请关注PHP中文网其他相关文章!