当前位置: 首页 > news >正文

SPN的重要性 | 保障服务安全和身份验证

什么是 Service Principal Name(SPN)?

SPN 是用于标识网络服务的唯一名称。在 Windows 中,SPN 与 Kerberos 认证一起使用。
SPN 是由两部分组成的:

  • 服务类型(Service Class): 表示服务的类型,如 HTTPSQLMSSQL 等。
  • 主机名(Host): 标识提供服务的实际主机。

一个完整的 SPN 形式为 service class/host:port. 例如,HTTP/server.example.comMSSQL/server.example.com:1433

SPN 的作用

  • Kerberos 认证: SPN 是在 Kerberos 认证中用于标识服务的方式。客户端和服务端之间的 Kerberos 通信依赖于正确配置的 SPN。

  • Delegation: SPN 也可以与委派(Delegation)一起配置,允许服务在用户身份上执行其他服务。

SPN 安全管控

SPN 安全性对于 Kerberos 认证的正常运行相关。
SPN 安全性要点:

  • 唯一性: 每个 SPN 必须在整个域中是唯一的。确保不同服务不使用相同的 SPN。

  • 安全权限: 修改或注册 SPN 需要适当权限。一般,只有域管理员或设置权限的用户才能执行配置。

  • SPN 注册: SPN 可以在用户或计算机账户上注册,也可以在服务账户上注册。

SPN 注册和管理:

  • 手动注册: 使用 setspn 命令手动注册和管理 SPN。

    setspn -S HTTP/server.example.com userAccount
    
  • 自动注册: 服务(如 SQL Server)在安装时会自动注册 SPN,后续根据实际生产需要手动调整。

问题排查和日志

  • 事件日志: 使用 Windows 事件查看器,检查 Kerberos 相关事件,在windows组件 kerberos 事件中查看 SPN 相关问题。关注事件 ID 3、4、14 等。

  • setspn 工具: 使用 setspn -Q 命令检查存在冲突的 SPN。

Kerberos 预身份验证

  • Kerberos 预身份验证(Constrained Delegation): 当使用 Kerberos 限制委派时,为服务配置正确的 SPN,以允许委派的服务。

示例场景

  • Web 服务: 对于托管在 IIS 上的 Web 服务,为对应的服务账户注册 HTTP SPN。

  • 数据库服务: 对于 SQL Server,注册 MSSQL SPN 以确保 Kerberos 认证。

SPN 安全管理

定期审查 SPN 配置:

  • 问题: 在系统或服务配置更改时,会影响 SPN 的正确性。
  • 安全管理: 定期审查 SPN 配置,发生以下情况时:
    • 服务迁移到新的服务器。
    • 更改了服务账户密码。
    • 有新服务引入或旧服务下线。

安全风险

  1. 身份伪装攻击:
  • 潜在风险: 恶意用户能够注册或修改错误的 SPN,尝试进行身份伪装攻击,伪装成合法服务来获取未经授权的访问。

  • 安全建议: 确保只有授权的管理员具有注册和修改 SPN 的权限,以减少身份伪装的风险。监控 SPN 注册,及时检测并纠正异常情况。

  1. Kerberos 票据窃取攻击:
  • 潜在风险: SPN 配置不当,导致 Kerberos 票据窃取攻击。攻击者通过在网络上抓取 Kerberos 票据或利用弱密码来获取用户的凭据。

  • 安全建议: 使用强密码策略,确保服务账户和用户账户的密码强度。定期检查 Kerberos 日志检测异常活动。

  1. Delegation 不当:
  • 潜在风险: 错误配置委派(Delegation)导致服务在用户的身份上执行其他服务,导致委派被滥用。

  • 安全建议: 仅为需要委派权限的服务账户启用委派,严格限制范围。避免直接为用户账户分配 SPN。

  1. 未经授权的 SPN 修改:
  • 潜在风险: 攻击者修改 SPN,引发身份验证和授权问题。

  • 安全建议: 限制对修改 SPN 的权限,仅允许授权的管理员执行此类操作。

  1. 配置错误导致服务中断:
  • 潜在风险: 不正确的 SPN 配置可能导致服务无法正常运行,造成业务中断。

  • 安全建议: 在更改系统或服务配置时,仔细审查和测试 SPN 的影响,确保不会引入不必要的风险。


~喜欢的话,请收藏 | 关注(✪ω✪)~
~万一有趣的事还在后头呢,Fight!!(o^-^)~''☆ミ☆ミ~……

相关文章:

  • 鸿蒙5.0发布时间已定!何处寻得移动开发加速器?
  • CWE、CVE
  • java中哈希家族底层原理
  • 扫码看文件效果怎么做?文件转成二维码能制作吗?
  • 写着玩的程序:pycharm实现无限弹窗程序(非病毒程序,仅整蛊使用)
  • PALWORLD linux centos7开服教程
  • 持续集成工具Jenkins的使用之安装篇(一)
  • vue和react的差异梳理
  • AWS认证SAA-C03每日一题
  • 【UE5】第一次尝试项目转插件(Plugin)的时候,无法编译
  • cad二次开发autolisp(一)
  • canvas绘制旋转的椭圆花
  • angular-tree-component组件中实现特定节点自动展开
  • package.json包版本控制方法介绍
  • 2024年 复习 HTML5+CSS3+移动web 笔记 之CSS遍
  • 【刷算法】求1+2+3+...+n
  • nfs客户端进程变D,延伸linux的lock
  • select2 取值 遍历 设置默认值
  • Solarized Scheme
  • Theano - 导数
  • vue2.0一起在懵逼的海洋里越陷越深(四)
  • 阿里研究院入选中国企业智库系统影响力榜
  • 不发不行!Netty集成文字图片聊天室外加TCP/IP软硬件通信
  • 不用申请服务号就可以开发微信支付/支付宝/QQ钱包支付!附:直接可用的代码+demo...
  • 大型网站性能监测、分析与优化常见问题QA
  • 动手做个聊天室,前端工程师百无聊赖的人生
  • 诡异!React stopPropagation失灵
  • 欢迎参加第二届中国游戏开发者大会
  • 基于OpenResty的Lua Web框架lor0.0.2预览版发布
  • 解析带emoji和链接的聊天系统消息
  • 前端攻城师
  • 网络应用优化——时延与带宽
  • 小程序上传图片到七牛云(支持多张上传,预览,删除)
  • 学习HTTP相关知识笔记
  • 一个完整Java Web项目背后的密码
  • 运行时添加log4j2的appender
  • 《码出高效》学习笔记与书中错误记录
  • 如何用纯 CSS 创作一个菱形 loader 动画
  • 资深实践篇 | 基于Kubernetes 1.61的Kubernetes Scheduler 调度详解 ...
  • ​ssh免密码登录设置及问题总结
  • # Java NIO(一)FileChannel
  • #laravel 通过手动安装依赖PHPExcel#
  • (NSDate) 时间 (time )比较
  • (八)Docker网络跨主机通讯vxlan和vlan
  • (附源码)小程序 交通违法举报系统 毕业设计 242045
  • (简单) HDU 2612 Find a way,BFS。
  • (蓝桥杯每日一题)平方末尾及补充(常用的字符串函数功能)
  • (每日持续更新)信息系统项目管理(第四版)(高级项目管理)考试重点整理第3章 信息系统治理(一)
  • (四)库存超卖案例实战——优化redis分布式锁
  • (转) SpringBoot:使用spring-boot-devtools进行热部署以及不生效的问题解决
  • (自用)learnOpenGL学习总结-高级OpenGL-抗锯齿
  • (最简单,详细,直接上手)uniapp/vue中英文多语言切换
  • .NET Core 实现 Redis 批量查询指定格式的Key
  • .NET 中使用 Mutex 进行跨越进程边界的同步
  • .NET连接数据库方式