0

0

如何为PHP应用快速集成OpenIDConnect?使用ronvanderheijden/openid-connect和Composer轻松实现安全认证。

DDD

DDD

发布时间:2025-10-25 11:16:30

|

168人浏览过

|

来源于php中文网

原创

如何为php应用快速集成openidconnect?使用ronvanderheijden/openid-connect和composer轻松实现安全认证。

可以通过一下地址学习composer学习地址

最近,我在为一个新项目构建认证服务时,就遇到了这样的困境。我们需要在现有的Laravel Passport基础上,增加OpenID Connect的支持,以便我们的前端应用能够通过标准的OIDC流程获取用户信息,并实现更灵活的身份验证。最初,我考虑自己手动扩展Laravel Passport,但很快意识到这会是一个巨大的工程,不仅要深入理解OIDC的每一个细节,还要确保与OAuth2服务器的兼容性,并妥善处理密钥管理和安全问题。这无疑会大大拖慢开发进度,并增加潜在的风险。

正当我为此感到头疼时,我发现了 ronvanderheijden/openid-connect 这个Composer包。它简直是为解决我的问题量身定制的!这个库专门为 thephpleague/oauth2-server 提供了OpenID Connect的支持,并且完美兼容Laravel Passport,这让我眼前一亮。

告别复杂,拥抱简洁:ronvanderheijden/openid-connect 的魅力

ronvanderheijden/openid-connect 的核心价值在于,它将OpenID Connect的复杂性封装起来,让我们可以像搭积木一样,在已有的OAuth2服务器上轻松添加OIDC功能。它通过扩展 league/oauth2-serverResponseType 机制,在OAuth2授权流程中注入了生成和返回 id_token 的能力。

安装过程简单直接,只需一行Composer命令:

立即学习PHP免费学习笔记(深入)”;

composer require ronvanderheijden/openid-connect

安装完成后,接下来就是配置密钥。OpenID Connect中的 id_token 是一个JSON Web Token (JWT),它需要使用私钥进行签名,并提供公钥供客户端验证。这个库对此也有清晰的指引:

mkdir -m 700 -p tmp

openssl genrsa -out tmp/private.key 2048
openssl rsa -in tmp/private.key -pubout -out tmp/public.key

chmod 600 tmp/private.key
chmod 644 tmp/public.key

这些命令会生成一个2048位的RSA私钥和对应的公钥,并将它们保存在 tmp 目录下。私钥用于签名 id_token,公钥则用于客户端验证签名的合法性。

如何集成到你的PHP应用(以 league/oauth2-server 为例)

如果你直接使用 league/oauth2-server,集成过程也很直观:

use OpenIDConnect\Entities\IdentityRepository;
use OpenIDConnect\Grant\AuthCodeGrant;
use OpenIDConnect\IdTokenResponse;
use OpenIDConnect\Claims\ClaimExtractor;
use Lcobucci\JWT\Configuration;
use Lcobucci\JWT\Signer\Key\InMemory;
use Lcobucci\JWT\Signer\Rsa\Sha256;
use League\OAuth2\Server\AuthorizationServer;
use League\OAuth2\Server\Repositories\AccessTokenRepositoryInterface;
use League\OAuth2\Server\Repositories\ClientRepositoryInterface;
use League\OAuth2\Server\Repositories\ScopeRepositoryInterface;
use Nyholm\Psr7\Factory\ServerRequestFactory;
use OpenIDConnect\Services\CurrentRequestService;

// ... (你的其他仓库和密钥配置) ...
$privateKeyPath = 'tmp/private.key';
$encryptionKey = 'def00000e700b08088b90b9b3921588669e4695027581b0a85233e7920786520b22a075308696d07e9d7240f9599554a9d7240f9599554a9'; // 示例加密密钥

$currentRequestService = new CurrentRequestService();
$currentRequestService->setRequest(ServerRequestFactory::fromGlobals());

// 创建 OpenID Connect 响应类型
$responseType = new IdTokenResponse(
    new IdentityRepository(), // 你的 Identity 仓库
    new ClaimExtractor(),
    Configuration::forSymmetricSigner(
        new Sha256(),
        InMemory::file($privateKeyPath),
    ),
    $currentRequestService,
    $encryptionKey,
);

$server = new AuthorizationServer(
    $clientRepository,
    $accessTokenRepository,
    $scopeRepository,
    $privateKeyPath, // 用于 OAuth2 的私钥路径
    $encryptionKey,  // 用于 OAuth2 的加密密钥
    $responseType // 注入 OpenID Connect 响应类型
);

// 如果需要 Nonce 支持,记得使用 OpenIDConnect\Grant\AuthCodeGrant
$server->enableGrantType(new AuthCodeGrant($userRepository, $authCodeRepository, $this->app->make(IdentityRepository::class), new \DateInterval('PT10M')), new \DateInterval('PT1H'));

现在,当客户端在授权请求中包含 openid scope时,服务器就会在响应中返回一个 id_token。如果你还提供了 profileemail 等其他OIDC标准scope,id_token 中还会包含相应的声明(claims),如用户的姓名、邮箱等。

Laravel Passport用户的福音

对于广大的Laravel开发者来说,这个库的集成更是无缝。它提供了专门的Laravel服务提供者,大大简化了配置:

Tago AI
Tago AI

AI生成带货视频,专为电商卖货而生

下载

1. 添加服务提供者:

config/app.php 中添加:

// config/app.php
'providers' => [
    // ... 其他服务提供者
    OpenIDConnect\Laravel\PassportServiceProvider::class,
],

2. 创建身份实体:

为了让 id_token 包含用户的额外信息(如邮箱),你需要创建一个 IdentityEntity 类,用于从你的 User 模型中收集这些“声明”(claims)。

// app/Entities/IdentityEntity.php
namespace App\Entities;

use App\Models\User; // 假设你的用户模型是 App\Models\User
use League\OAuth2\Server\Entities\Traits\EntityTrait;
use OpenIDConnect\Claims\Traits\WithClaims;
use OpenIDConnect\Interfaces\IdentityEntityInterface;

class IdentityEntity implements IdentityEntityInterface
{
    use EntityTrait;
    use WithClaims;

    protected User $user;

    public function setIdentifier($identifier): void
    {
        $this->identifier = $identifier;
        $this->user = User::findOrFail($identifier);
    }

    public function getClaims(): array
    {
        return [
            'email' => $this->user->email,
            'name' => $this->user->name, // 示例:添加用户姓名
            // ... 其他你希望包含在 id_token 中的声明
        ];
    }
}

通过 php artisan vendor:publish --tag=openid 命令,你还可以发布配置文件,进一步定制scope、claim集或仓库。

更棒的是,这个包还自动为Laravel Passport提供了OpenID Connect的 发现(Discovery)JWKS(JSON Web Key Set) 端点,这对于OIDC客户端来说是至关重要的,它们可以通过这些端点自动获取认证服务器的信息和公钥,实现自动配置。

  • 发现端点: /.well-known/openid-configuration
  • JWKS端点: /oauth/jwks

优势与实际应用效果

使用 ronvanderheijden/openid-connect 解决OIDC集成问题,带来了诸多显著优势:

  1. 极大地简化了OIDC实现:我们无需从头学习并实现复杂的OIDC规范,只需少量配置即可在现有OAuth2服务器上启用OIDC功能。
  2. 无缝兼容Laravel Passport:对于Laravel生态的开发者来说,这是福音。它让Laravel应用轻松升级,支持更广泛的认证场景。
  3. 增强了安全性:库本身处理了JWT的签名、加密、Nonce支持等关键安全机制,减少了手动实现可能带来的安全漏洞。
  4. 标准化与互操作性:遵循OpenID Connect标准,确保了与各种OIDC客户端(如移动应用、前端SPA、其他服务)的良好互操作性。
  5. 减少开发时间与成本:将我们从繁琐的认证细节中解放出来,可以更专注于核心业务逻辑的开发。
  6. 易于维护和扩展:基于Composer和现有OAuth2服务器,使得后续的维护和功能扩展变得更加简单。

通过集成 ronvanderheijden/openid-connect,我们的项目不仅成功实现了OpenID Connect认证,还显著提升了开发效率和系统的安全性。它让我们能够轻松地为用户提供更现代、更安全的认证体验。如果你也在为PHP应用集成OpenID Connect而烦恼,强烈推荐你尝试这个强大的Composer包!

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
laravel组件介绍
laravel组件介绍

laravel 提供了丰富的组件,包括身份验证、模板引擎、缓存、命令行工具、数据库交互、对象关系映射器、事件处理、文件操作、电子邮件发送、队列管理和数据验证。想了解更多laravel的相关内容,可以阅读本专题下面的文章。

320

2024.04.09

laravel中间件介绍
laravel中间件介绍

laravel 中间件分为五种类型:全局、路由、组、终止和自定。想了解更多laravel中间件的相关内容,可以阅读本专题下面的文章。

278

2024.04.09

laravel使用的设计模式有哪些
laravel使用的设计模式有哪些

laravel使用的设计模式有:1、单例模式;2、工厂方法模式;3、建造者模式;4、适配器模式;5、装饰器模式;6、策略模式;7、观察者模式。想了解更多laravel的相关内容,可以阅读本专题下面的文章。

373

2024.04.09

thinkphp和laravel哪个简单
thinkphp和laravel哪个简单

对于初学者来说,laravel 的入门门槛较低,更易上手,原因包括:1. 更简单的安装和配置;2. 丰富的文档和社区支持;3. 简洁易懂的语法和 api;4. 平缓的学习曲线。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

374

2024.04.10

laravel入门教程
laravel入门教程

本专题整合了laravel入门教程,想了解更多详细内容,请阅读专题下面的文章。

85

2025.08.05

laravel实战教程
laravel实战教程

本专题整合了laravel实战教程,阅读专题下面的文章了解更多详细内容。

65

2025.08.05

laravel面试题
laravel面试题

本专题整合了laravel面试题相关内容,阅读专题下面的文章了解更多详细内容。

68

2025.08.05

composer是什么插件
composer是什么插件

Composer是一个PHP的依赖管理工具,它可以帮助开发者在PHP项目中管理和安装依赖的库文件。Composer通过一个中央化的存储库来管理所有的依赖库文件,这个存储库包含了各种可用的依赖库的信息和版本信息。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

154

2023.12.25

Golang 网络安全与加密实战
Golang 网络安全与加密实战

本专题系统讲解 Golang 在网络安全与加密技术中的应用,包括对称加密与非对称加密(AES、RSA)、哈希与数字签名、JWT身份认证、SSL/TLS 安全通信、常见网络攻击防范(如SQL注入、XSS、CSRF)及其防护措施。通过实战案例,帮助学习者掌握 如何使用 Go 语言保障网络通信的安全性,保护用户数据与隐私。

2

2026.01.29

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
第二十四期_PHP8编程
第二十四期_PHP8编程

共86课时 | 3.4万人学习

成为PHP架构师-自制PHP框架
成为PHP架构师-自制PHP框架

共28课时 | 2.5万人学习

第二十三期_PHP编程
第二十三期_PHP编程

共93课时 | 6.9万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号