>本教程演示了使用Laravel Passport库在Laravel应用程序中构建强大的OAuth2服务器。我们将介绍服务器配置,并提供消耗OAuth2 API的实践示例。 假定基本的OAuth2知识。 Laravel护照大大简化了该过程。
>教程分为两个部分:库安装和配置,然后创建和消费示例资源。
服务器配置
本节详细详细安装和配置护照的必要组件以使用Laravel运行。
>安装Laravel Passport Library>
使用Composer安装库:
composer require laravel/passport
启用护照服务
> Laravel使用服务提供商来管理应用程序服务。要启用护照,您需要将其服务提供商添加到。 (如果不熟悉Laravel服务提供商,请参考相关的介绍资源。)至关重要的是,您还必须注册Passport的路由(在
>的方法中)并运行config/app.php
命令。此命令还允许客户端创建。让我们创建一个演示客户端。boot
app/Providers/AuthServiceProvider.php
php artisan passport:install
命令提示以获取详细信息:用户ID,客户端名称和重定向URI。 重定向URI是授权后用户重定向的地方,携带授权代码。
php artisan passport:client
现在,我们可以测试oauth2 apis。
在此示例中,我们将在文档root中创建
<code>New client created successfully. Client ID: 3 Client secret: 1BT1tNj0Are27IGvIZe4lE2jRjtiVt0fmtaWBe8m</code>
>
createoauth2_client/auth_redirection.php oauth2_client
:
记住将占位符和
替换为您的实际值。<?php $query = http_build_query([ 'client_id' => '3', 'redirect_uri' => 'http://localhost/oauth2_client/callback.php', 'response_type' => 'code', 'scope' => '', ]); header('Location: http://your-laravel-site-url/oauth/authorize?' . $query); ?>
接下来,创建client_id
oauth2_client/callback.php redirect_uri
:
再次,根据需要调整URL和凭据。>
<?php if (isset($_REQUEST['code']) && $_REQUEST['code']) { $ch = curl_init(); $url = 'http://your-laravel-site-url/oauth/token'; $params = [ 'grant_type' => 'authorization_code', 'client_id' => '3', 'client_secret' => '1BT1tNj0Are27IGvIZe4lE2jRjtiVt0fmtaWBe8m', 'redirect_uri' => 'http://localhost/oauth2_client/callback.php', 'code' => $_REQUEST['code'], ]; curl_setopt($ch, CURLOPT_URL, $url); curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1); $params_string = ''; if (is_array($params) && count($params)) { foreach ($params as $key => $value) { $params_string .= $key . '=' . $value . '&'; } rtrim($params_string, '&'); curl_setopt($ch, CURLOPT_POST, count($params)); curl_setopt($ch, CURLOPT_POSTFIELDS, $params_string); } $result = curl_exec($ch); curl_close($ch); $response = json_decode($result); if (isset($response->access_token) && $response->access_token) { $access_token = $response->access_token; $ch = curl_init(); $url = 'http://your-laravel-site-url/api/user/get'; $header = ['Authorization: Bearer ' . $access_token]; $query = http_build_query(['uid' => '1']); curl_setopt($ch, CURLOPT_URL, $url . '?' . $query); curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1); curl_setopt($ch, CURLOPT_HTTPHEADER, $header); $result = curl_exec($ch); curl_close($ch); $response = json_decode($result); var_dump($result); } } ?>
用户与两个应用程序进行交互:Laravel应用程序(与现有帐户)和第三方客户端(auth_redirection.php和callback.php)。
http://localhost/oauth2_client/auth_redirection.php
。http://localhost/oauth2_client/callback.php
callback.php
访问令牌用于进行API调用(例如,http://your-laravel-site-url/api/user/get
>本教程展示了Laravel Passport在设置OAuth2服务器方面的易用性。 要进行进一步的Laravel开发资源,请探索Envato市场。
以上是使用Laravel中的Passport设置OAuth2服务器的详细内容。更多信息请关注PHP中文网其他相关文章!