使用 Symfony 和 SAML 2.0 SSO 保护静态 Twig 路由

使用 symfony 和 saml 2.0 sso 保护静态 twig 路由

本文档介绍如何使用 Symfony 框架和 SAML 2.0 单点登录 (SSO) 来保护静态网站的 Twig 路由。我们将使用 hslavich/OneloginSamlBundle 集成 SAML 认证,并配置 Symfony 的安全组件来限制对特定路由的访问,确保只有经过身份验证的用户才能访问这些页面。

配置 Symfony 项目以支持 SAML 2.0 SSO

本教程将指导你如何设置一个 Symfony 项目,该项目通过 SAML 2.0 SSO 提供静态 Twig 路由。我们将使用 hslavich/OneloginSamlBundle 来简化 SAML 集成。

1. 安装 OneloginSamlBundle

首先,使用 Composer 安装 hslavich/OneloginSamlBundle:

composer require hslavich/onelogin-saml-bundle

2. 配置 OneloginSamlBundle

根据你的服务提供商 (SP) 和身份提供商 (IdP) 的配置,填写 config/packages/hslavich_onelogin_saml.yaml 文件。请参考该 Bundle 的 README.md 文件获取详细的配置说明。

一个重要的注意事项是,baseurl 配置值应该设置为应用程序的域名, 附加 /saml。例如:http://myapp.com/saml。这是因为 Bundle 中存在一个 bug,它会移除最后一个路径值(例如 /saml/acs 中的 acs)和域名之间的所有内容。

一个典型的配置示例如下:

# config/packages/hslavich_onelogin_saml.yamlhslavich_onelogin_saml:    sp:        entityid: "your_sp_entity_id"        assertion_consumer_service:            url: "http://myapp.com/saml/acs"        single_logout_service:            url: "http://myapp.com/saml/sls"        NameIDFormat: "urn:oasis:names:tc:SAML:1.1:nameid-format:emailAddress"        x509cert: "YOUR_SP_CERTIFICATE"        privateKey: "YOUR_SP_PRIVATE_KEY"    idp:        entityid: "your_idp_entity_id"        single_sign_on_service:            url: "your_idp_sso_url"        single_logout_service:            url: "your_idp_slo_url"        x509cert: "YOUR_IDP_CERTIFICATE"    security:        username_mapper: HslavichOneloginSamlBundleSecurityUserAttributeUserMapper

请确保将 YOUR_SP_CERTIFICATE, YOUR_SP_PRIVATE_KEY, your_idp_entity_id, your_idp_sso_url, your_idp_slo_url 和 YOUR_IDP_CERTIFICATE 替换为你的实际值。

3. 配置 Symfony 安全组件

更新 config/packages/security.yaml 文件以集成 SAML 认证。

security:    enable_authenticator_manager: true    providers:        saml_provider:            saml:                user_class: AppSecurityUser                default_roles:                    - ROLE_USER        app_user_provider:            id: AppSecurityUserProvider # 可选,如果你需要自定义 UserProvider    firewalls:        dev:            pattern: ^/(_(profiler|wdt)|css|images|js)/            security: false        app:            saml:                provider: saml_provider                username_attribute: eduPersonTargetedID # 映射 SAML 属性到用户名                check_path: saml_acs # SAML Assertion Consumer Service 路径                login_path: saml_login # SAML 登录路径            logout:                path: saml_logout # SAML 登出路径        main:            lazy: true            provider: app_user_provider # 可选,如果你需要自定义 UserProvider    access_control:        - { path: ^/saml/login, roles: PUBLIC_ACCESS } # 允许匿名访问 SAML 登录路径        - { path: ^/saml/metadata, roles: PUBLIC_ACCESS } # 允许匿名访问 SAML 元数据路径        - { path: ^/, roles: ROLE_USER } # 所有其他路径需要 ROLE_USER 角色

解释:

providers: 定义了 saml_provider,它使用 saml 驱动,并指定了用户类和默认角色。 app_user_provider是可选的,如果需要自定义用户提供者则需要配置。firewalls: 定义了 app 防火墙,它使用 saml 认证。username_attribute: 指定了用于匹配用户名的 SAML 属性。 默认情况下,它使用 getNameId() 方法,但你可以将其配置为使用任何其他的 SAML 属性。check_path: 定义了 SAML Assertion Consumer Service (ACS) 的路径。login_path: 定义了 SAML 登录路径。logout: 定义了 SAML 登出路径。access_control: 定义了访问控制规则。/saml/login 和 /saml/metadata 路径允许公开访问。所有其他路径需要 ROLE_USER 角色。

4. 创建 User 类 (AppSecurityUser)

创建一个 AppSecurityUser 类,实现 SymfonyComponentSecurityCoreUserUserInterface 接口。这个类将代表经过 SAML 认证的用户。

username = $username;        $this->roles = $roles;    }    public function getUsername(): string    {        return $this->username;    }    public function getRoles(): array    {        return $this->roles;    }    public function getPassword(): ?string    {        return null; // SAML 认证不需要密码    }    public function getSalt(): ?string    {        return null; // SAML 认证不需要 salt    }    public function eraseCredentials()    {        // 如果需要,可以在这里清除敏感数据    }    public function getUserIdentifier(): string    {        return $this->username;    }}

5. (可选) 创建 UserProvider 类 (AppSecurityUserProvider)

如果你需要自定义用户加载逻辑,可以创建一个 AppSecurityUserProvider 类,实现 SymfonyComponentSecurityCoreUserUserProviderInterface 接口。

loadUserByIdentifier($user->getUserIdentifier());    }    public function supportsClass(string $class): bool    {        return User::class === $class;    }    public function loadUserByUsername(string $username): UserInterface    {        return $this->loadUserByIdentifier($username);    }}

6. 创建 Twig 模板和控制器

创建你的 Twig 模板和控制器来显示静态内容。例如:

render('home/index.html.twig', [            'message' => 'Welcome to the secured area!',        ]);    }}
{# templates/home/index.html.twig #}

{{ message }}

You are logged in!

Logout

7. 测试

现在,访问你的应用程序的根路径(例如 http://myapp.com/)。你将被重定向到 IdP 进行身份验证。成功认证后,你将被重定向回应用程序,并可以访问受保护的页面。

总结

通过以上步骤,你已经成功配置了一个 Symfony 项目,该项目使用 hslavich/OneloginSamlBundle 和 SAML 2.0 SSO 来保护静态 Twig 路由。 /saml/login 和 /saml/metadata 路径可以公开访问,而所有其他路由都需要 ROLE_USER 角色。 用户成功通过 IdP 身份验证后,将被重定向回来并获得会话,然后可以访问站点中的所有路由。

注意事项:

确保你的 SP 和 IdP 配置正确。在生产环境中,使用 HTTPS 来保护 SAML 消息。定期更新 hslavich/OneloginSamlBundle 以获取最新的安全补丁。根据你的需求自定义用户加载逻辑。仔细阅读 hslavich/OneloginSamlBundle 的文档以获取更多高级配置选项。

以上就是使用 Symfony 和 SAML 2.0 SSO 保护静态 Twig 路由的详细内容,更多请关注php中文网其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/89617.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年11月18日 05:42:18
下一篇 2025年11月18日 06:31:19

相关推荐

  • 币圈空投在哪获取 怎样才能得到空投奖励

    本文将围绕“币圈空投在哪获取”和“怎样才能得到空投奖励”这两个问题进行讲解,帮助用户掌握有效参与空投的方式。 什么是币圈空投 空投是一种数字资产项目方在新币上线前后,用于吸引用户注意力的一种推广方式。通常用户只需完成一些简单任务,如关注社交平台、填写表单、加入社群等,即可获得一定数量的代币奖励。 获…

    2025年12月8日
    000
  • 币圈空投在哪获取 怎么参加币圈空投

    本文将帮助用户理解空投的获取渠道以及具体参与步骤,并且结合实际操作流程,提供一套清晰的参考方式。 什么是币圈空投? 币圈空投是指项目方为了扩大影响力或奖励社区用户,将一定数量的数字资产免费发放给符合条件的用户。这种方式在区块链项目初期较为常见,尤其在推广新币时使用频繁。 获取空投的主要渠道 1、项目…

    2025年12月8日
    000
  • 币圈白嫖指南:空投奖励怎么领最划算

    “空投”指的是项目方向用户免费发放代币的一种推广手段。本文将详细介绍如何领取空投奖励。 什么是空投,为什么会有空投? 空投通常用于项目早期吸引关注度、鼓励用户参与社区建设或测试网络功能。通过空投,用户可以以低成本获取潜力代币,而项目方则能迅速扩大影响力。 领取空投的基本流程 1、创建账户:准备一个支…

    2025年12月8日
    000
  • 币圈空投是真的吗?币圈空投网址大全

    本文将简要介绍怎样判断空投真实性的方法,并推荐一些靠谱的空投平台和资源,帮助你安全参与和学习操作流程。 如何判断空投是否真实 以下步骤可以帮助辨别真假: 1、核实官方来源:查看项目官网、X/Twitter、Telegram或Discord官方发布渠道,绝不通过非官方链接参与。 2、不提供私钥或助记词…

    2025年12月8日
    000
  • 币圈免费空投怎么找 怎样才能领取到币圈空投

    本文将从信息获取、项目验证到实际操作流程寻找并成功领取币圈空投。通过这些步骤,可以更高效地参与空投活动 1、寻找空投信息的主要渠道 想要参与空投,第一步是获取可靠的信息来源。以下是常见的空投信息渠道: (1)空投聚合平台:如AirdropAlert、CoinMarketCap Airdrops等,这…

    2025年12月8日
    000
  • OpenSea的移动端转型:Rally收购与NFT交易的未来

    opensea 收购 rally,重塑移动端 nft 交易格局。本文将探讨这一举措对创作者、收藏者以及链上经济的影响,并分析当前不断变化的 nft 市场格局。 OpenSea 的移动战略:收购 Rally 与 NFT 交易的未来 NFT 领域近期因 OpenSea 的一项重要动作引发广泛关注:公司正…

    2025年12月8日
    000
  • 人形机器人、情感智能与人工智能:未来已来

    探索人形机器人、情感智能与人工智能技术交汇的无限可能,聚焦 realbotix 的最新突破及推动未来发展的关键趋势。 人形机器人、情感智能与人工智能:未来已来 人形机器人、情感智能与人工智能的结合早已跳脱科幻范畴。Realbotix 正在这一领域开疆拓土,推出具备情感识别、自然互动和多感官感知能力的…

    2025年12月8日
    000
  • 币圈热门币种有哪些?2025年-2030年热门币种价格预测

    在瞬息万变的数字资产市场中,识别具有长期潜力的项目是参与者关注的焦点。本文将深入探讨当前市场上的几个主流热门币种,并基于其技术基础、生态系统发展和市场趋势,展望它们在2025年至2030年期间的潜在价值走向。 热门%ignore_a_1%官方地址汇总 币安Binance:  ()欧易OKX:  ()…

    2025年12月8日
    000
  • 跨链和兼容性的关键:以太坊EVM的生态优势

    跨链和兼容性是当前区块链技术发展的关键点之一,而以太坊EVM(Ethereum Virtual Machine)在这方面扮演着极为重要的角色。本文将围绕以太坊EVM的生态优势展开说明,介绍其在支持跨链互通和协议兼容方面的机制与优势,并简要梳理其如何成为多个链上项目首选的技术基础。 2025主流加密货…

    2025年12月8日
    000
  • 币圈项目空投怎么查?如何避免假空投骗局?

    查找加密货币项目的空投机会,是许多参与者希望获取早期项目代币的方式。这些空投通常是项目方推广品牌、社区建设或者激励早期用户的一种手段。要有效地找到这些信息,需要依赖多个可靠的渠道和方法。 查询空投信息需要保持警惕,因为互联网上充斥着各种真假难辨的信息。识别可靠的信息源是第一步。许多项目会在其官方网站…

    2025年12月8日
    000
  • 多链共识的技术基础 EVM兼容正在改变DeFi和dApp的发展路线

    本文围绕“多链共识的技术基础”以及“EVM兼容正在改变DeFi和dApp的发展路线”两大主题进行解析,主要介绍多链共识的关键技术原理,并进一步说明EVM兼容如何助推跨链生态发展。在多链布局成为趋势的背景下,这些技术的融合正在对去中心化金融和应用产生重要影响。 2025主流加密货币交易所官网注册地址推…

    2025年12月8日
    000
  • 狗狗币DOGE属于哪条链?狗狗币是否属于币安链?

    近期,数字资产领域的讨论热度不减,狗狗币doge作为其中一个备受关注的焦点,其技术基础和平台归属成为不少人探索的疑问。它究竟“安家”何处?又与当前头部交易平台——币安有怎样的关联?要解答这些问题,我们需要从数字资产的底层技术逻辑和平台生态两个维度进行深入剖析,而非仅仅停留在表象。 一、狗狗币DOGE…

    2025年12月8日
    000
  • 全球主流加密货币有哪些?2025年加密货币深度分析(含网址)

    在数字经济浪潮席卷全球的当下,加密货币以其独特的去中心化、透明化特性,成为各界关注的焦点。从最初的极客小众实验,到如今市值数万亿的金融版图,加密货币的演变轨迹令人惊叹。它不仅带来了底层技术的革新,也催生了无数创新应用,正深刻影响着金融、科技乃至社会治理的方方面面。无论是普通投资者对财富增值的期盼,还…

    2025年12月8日
    000
  • 币圈反指是什么意思?为什么有人专门反向操作?市场情绪指标

    币圈“反指”,顾名思义,指的是那些其观点或操作往往与市场实际走势相反的参照对象。当这样的人或群体极度看好时,市场可能面临下跌;当他们极度悲观时,市场反而可能迎来反弹。这并非说这些人故意提供错误的信号,而是他们的判断可能与市场的主流趋势存在偏差,或者他们的操作行为在某种特定情境下恰好成为市场逆转的催化…

    2025年12月8日
    000
  • 领涨2025加密市场的前二十大代币排行榜(最新更新)

    随着新周期的临近,投资者正积极寻找有望在2025年引领市场的加密资产。本榜单基于项目技术、生态系统发展、社区活跃度和市场叙事,精选出20个具备巨大潜力的代币,旨在为您的研究和决策提供参考。 主流代币%ignore_a_1%推荐 币安Binance:  ()欧易OKX:  () Huobi火币:   …

    2025年12月8日 好文分享
    000
  • Hedera、Kaspa 与 2025 年的加密货币:有什么热议?

    在2025年持续演进的加密货币市场中,hedera(hbar)与kaspa(kas)正逐渐成为投资者关注的焦点。探索它们的关键趋势、深度洞察以及可能的投资方向。 随着加密行业迈入2025年,市场的注意力越来越多地集中于那些具备实际应用潜力的项目上。让我们聚焦于Hedera(HBAR)和Kaspa(K…

    2025年12月8日
    000
  • ₹50硬币难题:公众偏好与德里高等法院

    德里高等法院正就是否引入50卢比硬币展开讨论,这一议题牵涉到视障人士的使用便利性及公众对纸币的偏好问题。 50卢比硬币争议:公众习惯与法院审议 目前,德里高等法院正在评估推行50卢比硬币的可行性。这场争论涉及公众使用习惯、无障碍设计以及政府立场等多个层面。我们一起来了解具体情况。 暂无发行计划 收藏…

    2025年12月8日
    000
  • 以太坊币10年历史价格走势

    %ignore_a_1%十年价格波动受技术升级、市场情绪、监管政策等多因素影响,其关键里程碑包括2015年主网上线、2017年ICO热潮推动价格飙升、2020年DeFi兴起、2021年NFT爆发、2022年“合并”升级及2023年逐步复苏。获取历史价格数据可通过CoinMarketCap或CoinG…

    2025年12月8日
    000
  • 2025 年下半年比特币及加密货币市场分析

    主流货币交易平台: 欧易OKX: Binance币安: 火币Huobi: Gateio芝麻开门: 2025年下半年,加密货币市场将再次成为全球关注的焦点,其独特的波动性与前沿科技魅力交织,持续吸引着各类投资者与创新者。比特币作为数字黄金的代表,以及更广泛的加密货币生态系统,正处于一个充满复杂性与机遇…

    2025年12月8日
    000
  • ETH vs BSC vs Solana:三大公链优劣全剖析,一文搞懂投资逻辑

    当前区块链生态持续扩张,ethereum(eth)、binance smart chain(bsc) 与 solana 成为最受关注的三大公链体系。本文将对这三者进行全方位分析,帮助读者明确不同链的优势与风险,厘清适合自身的投资逻辑。 2025主流加密货币交易所官网注册地址推荐: 欧易OKX: Bi…

    2025年12月8日 好文分享
    000

发表回复

登录后才能评论
关注微信