0

0

SAML断言是什么 如何用XML格式进行身份验证

畫卷琴夢

畫卷琴夢

发布时间:2026-01-16 12:42:09

|

865人浏览过

|

来源于php中文网

原创

SAML断言是由IdP签发、SP验证的声明凭证,包含AuthnStatement(身份验证)和AttributeStatement(属性)两类核心声明,必须签名、有时效、绑定正确主体,且需经Base64编码+DEFLATE压缩后通过HTTP POST传输。

saml断言是什么 如何用xml格式进行身份验证

什么是 SAML 断言(SAML Assertion

SAML Assertion 是 SAML 协议中承载身份验证、属性和授权决策的核心 XML 结构。它不是“登录动作”,而是由身份提供者(IdP)签发的、可被服务提供者(SP)验证的**声明凭证**——类似一张带防伪印章的电子身份证。

一个 SAML Assertion 通常包含三类声明(),但实际生产中绝大多数只用前两者:前者证明“用户刚通过某种方式登录了”,后者传递“这个用户的邮箱是 xxx@domain.com”这类属性。

如何构造一个最小可用的 SAML 断言 XML

手动写完整断言不现实,但理解结构能帮你快速排查错误。关键点在于:必须有签名、必须有时效、必须绑定正确主体。以下是一个简化但可被主流 SP(如 Okta、Azure AD 测试端点)接受的 AuthnStatement-only 断言片段:


  https://idp.example.com
  
    
  
  
    user@example.com
    
      
      
    
  
  
    
      
        urn:oasis:names:tc:SAML:2.0:ac:classes:PasswordProtectedTransport
      
    
  

注意这些硬性要求:

  • ID 必须以 _ 开头,且全局唯一(不能重复使用)
  • IssueInstantNotOnOrAfter 时间必须在 SP 接收时处于有效窗口(常见容忍 ±3 分钟)
  • Recipient 必须与 SP 的 AssertionConsumerServiceURL 完全一致(含协议、大小写、尾部斜杠)
  • 没有 的断言会被所有合规 SP 拒绝 —— 即使内容合法

为什么直接 POST 这个 XML 到 SP 不会成功

你不能把上面那段 XML 直接 curl -X POST 给 SP 的 /acs 地址。SAML 身份验证依赖严格的消息封装机制:

PicWish
PicWish

推荐!专业的AI抠图修图,支持格式转化

下载
  • SP 期望收到的是一个 SAMLResponse 参数,其值是上述 Assertion 的 **base64 编码 + DEFLATE 压缩**(不是纯 base64)
  • 整个请求必须是 application/x-www-form-urlencoded,且通常还需附带 RelayState 参数(用于跳转回原始请求页面)
  • IdP 必须用 SP 提供的 X.509 证书公钥对 内容进行签名,SP 用同一证书验签
  • 部分 SP(如 AWS SSO)还强制要求 中包含 NotBeforeAudienceRestriction

换句话说:手写 XML 只是“填空”,真正跑通需要 IdP 侧完成编码、压缩、签名、HTTP 封装整套流程。调试时建议用浏览器开发者工具抓取真实 IdP 返回的 SAMLResponse 值,再 base64 解码查看原始 XML —— 这比自己拼更可靠。

常见失败原因和验证要点

当 SP 返回 InvalidRequestRequestDenied 或静默失败时,优先检查:

  • XML 命名空间是否完整且拼写正确:urn:oasis:names:tc:SAML:2.0:assertion 不能少字母或换行截断
  • 的值是否与 SP 配置的 IdP 实体 ID **逐字符一致**(包括末尾斜杠)
  • 签名是否覆盖整个 元素(而非仅子节点);很多库默认签名范围错误
  • 系统时间偏差:IdP 和 SP 服务器时间差超过 5 分钟会导致 NotOnOrAfter 验证失败
  • SP 是否启用宽松模式?例如某些测试 SP(如 samltest.id)允许无签名断言,但生产环境一律禁用

最易被忽略的一点:SAML 断言本身不包含密码或令牌,它只是“我证明这个人已登录”的声明。验证成败完全取决于签名有效性、时间窗口、URI 匹配度这三项 —— 和用户密码无关,也和 SP 是否存了该用户账号无关。

相关专题

更多
pdf怎么转换成xml格式
pdf怎么转换成xml格式

将 pdf 转换为 xml 的方法:1. 使用在线转换器;2. 使用桌面软件(如 adobe acrobat、itext);3. 使用命令行工具(如 pdftoxml)。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

1878

2024.04.01

xml怎么变成word
xml怎么变成word

步骤:1. 导入 xml 文件;2. 选择 xml 结构;3. 映射 xml 元素到 word 元素;4. 生成 word 文档。提示:确保 xml 文件结构良好,并预览 word 文档以验证转换是否成功。想了解更多xml的相关内容,可以阅读本专题下面的文章。

2085

2024.08.01

xml是什么格式的文件
xml是什么格式的文件

xml是一种纯文本格式的文件。xml指的是可扩展标记语言,标准通用标记语言的子集,是一种用于标记电子文件使其具有结构性的标记语言。想了解更多相关的内容,可阅读本专题下面的相关文章。

999

2024.11.28

curl_exec
curl_exec

curl_exec函数是PHP cURL函数列表中的一种,它的功能是执行一个cURL会话。给大家总结了一下php curl_exec函数的一些用法实例,这个函数应该在初始化一个cURL会话并且全部的选项都被设置后被调用。他的返回值成功时返回TRUE, 或者在失败时返回FALSE。

425

2023.06.14

linux常见下载安装工具
linux常见下载安装工具

linux常见下载安装工具有APT、YUM、DNF、Snapcraft、Flatpak、AppImage、Wget、Curl等。想了解更多linux常见下载安装工具相关内容,可以阅读本专题下面的文章。

174

2023.10.30

http500解决方法
http500解决方法

http500解决方法有检查服务器日志、检查代码错误、检查服务器配置、检查文件和目录权限、检查资源不足、更新软件版本、重启服务器或寻求专业帮助等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

344

2023.11.09

http请求415错误怎么解决
http请求415错误怎么解决

解决方法:1、检查请求头中的Content-Type;2、检查请求体中的数据格式;3、使用适当的编码格式;4、使用适当的请求方法;5、检查服务器端的支持情况。更多http请求415错误怎么解决的相关内容,可以阅读下面的文章。

407

2023.11.14

HTTP 503错误解决方法
HTTP 503错误解决方法

HTTP 503错误表示服务器暂时无法处理请求。想了解更多http错误代码的相关内容,可以阅读本专题下面的文章。

1754

2024.03.12

C++ 单元测试与代码质量保障
C++ 单元测试与代码质量保障

本专题系统讲解 C++ 在单元测试与代码质量保障方面的实战方法,包括测试驱动开发理念、Google Test/Google Mock 的使用、测试用例设计、边界条件验证、持续集成中的自动化测试流程,以及常见代码质量问题的发现与修复。通过工程化示例,帮助开发者建立 可测试、可维护、高质量的 C++ 项目体系。

3

2026.01.16

热门下载

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

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
最新Python教程 从入门到精通
最新Python教程 从入门到精通

共4课时 | 0.9万人学习

Rust 教程
Rust 教程

共28课时 | 4.4万人学习

Git 教程
Git 教程

共21课时 | 2.7万人学习

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

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