Kerberos身份验证

news2024/12/18 9:13:01

Kerberos是更现代化的身份验证协议,它比 NTLM 认证更安全,但域内某些服务仍支持 NTLM 认证。Kerberos 和 NTLM 认证一样,都是通过在 SSPI 接口实现的功能,这使得使用第三方协议(如:HTTP、SMB、LDAP)在访问服务之前,Kerberos 和 NTLM 一样,由身份验证阶段转为会话阶段。

我们之前的文章表明,NTLM 身份验证阶段就是客户端和服务端展开的协商、挑战、验证,会话阶段就是使用 HTTP、SMB、LDAP 访问服务,那么这里的会话阶段与 Kerberos 身份验证后的会话阶段没有什么不同,我们把重点放在 Kerberos身份验证阶段。

Kerberos 身份验证阶段分为如下步骤:

  • as-req & as-rep

  • tgs-req & tgs-rep

  • ap-req & ap-rep

经过上述步骤后进入会话阶段。

as-req & as-rep

  • 此步骤用于客户端向 kdc 请求 tgt 认购权证

  • as-req :客户端发送请求

  • as-rep :kdc 返回 tgt 认购权证

 

上图是 as-req 请求内容,和 as-rep 响应内容。我来详细解释其中的细节。

tgt 请求流程
  1. 客户端使用某个域用户的身份凭据(用户密码)生成用户 hash。

  2. 客户端使用用户 hash 加密时间戳,并和一系列其他信息组成 as-req 发送给 kdc 以访问 kdc 的 krbtgt 服务(此服务主要用来颁发 tgt )。

  3. kdc 从活动目录数据库中取出用户凭据并生成用户 hash,并尝试用这个自己运算出来的用户 hash 解密时间戳

    • 解密成功:用户凭据正确

    • 解密失败:用户凭据错误

  1. 解密成功后,利用此用户在活动目录数据库中的信息生成针对此用户的 tgt 认购权证。

as-rep 内容详解
  1. 生成 tgt 的同时,kdc 也生成了一个随机化的 Logon Session Key,其存储位置有两个:

    • Logon Session Key 经过用户 hash 加密后存放在 tgt 之外。

    • Logon Session Key 经过 krbtgt 服务账户 hash 加密后放在 tgt 内部。

  2. 除了 Logon Session Key 之外,tgt 内部最重要的信息就是 PAC。

    • PAC 是 krbtgt 服务在活动目录查询访问用户后,生成的一系列关于此用户的权限信息(例如:所属组等)

    • 通过 PAC,目标服务能获取用户所属组等身份,再根据配置在本地的 ACL ,不需要再次访问 kdc 就能判断用户权限。因此 PAC 不能被用户解密。

  3. PAC 受 serverchecksum 和 privsvrchecksum 两个签名的保护:

    • privsvrchecksum :使用 krbtgt 服务账户 hash 进行签名

    • serverchecksum :使用即将要访问的目标服务的服务账号 hash 进行签名(因为这里这里请求了 tgt 所以此时的目标服务的服务账号 hash 就是 krbtgt 服务账户 hash ,可以说这里的 privsvrchecksum 和 serverchecksum 是一样的)

  4. Logon Session Key 的作用出现在 tgs-req & tgs-rep。

tgs-req & tgs-rep

  • 此步骤用于客户端向 kdc 请求 st 服务票据

  • tgs-req :客户端发送请求

  • tgs-rep :kdc 返回 st 服务票据

 

上图是 as-req 请求内容,和 as-rep 响应内容。我来详细解释其中的细节。

st 请求流程
  1. 客户端接受到 as-rep 后,使用用户 hash 解密被加密的 Logon Session Key。

  2. 客户端使用 Logon Session Key 加密时间戳,并和 tgt 、以及其他一系列其他信息组成 tgs-req 发送给 kdc 以访问 kdc ,此时请求的服务名已不再是 krbtgt 服务账户,而是目标服务的服务账户。

  3. kdc 获取客户端发来的 tgt ,并使用 krbtgt 服务账户的 hash 解密其中的 Logon Session Key ,并尝试用 Logon Session Key 来解密 Logon Session Key 解密时间戳。

    • 解密成功:用户凭据正确

    • 解密失败:用户凭据错误

    • as-rep 中 tgt 外部的 Logon Session Key :供用户使用,作为 tgs-req 中时间戳的密钥来加密的时间戳向 kdc 发起验证。

    • as-rep 中 tgt 内部的 Logon Session Key :供 kdc 使用,用来验证 tgs-req 加密的时间戳。

  1. 解密成功后,通常情况下,kdc 会直接将接受的 tgt 的大部分信息复制到 st中。

  2. 修改 serverchecksum :从 krbtgt 服务账户 hash 进行签名替换为使用目标服务账户 hash 进行签名。

tgs-rep 详细内容
  1. 生成 tgt 的同时,kdc 也生成了一个随机化的 Server Session Key,其存储位置有两个:

    • Server Session Key 经过Logon Session Key加密后存放在 tgt 之外。

    • Server Session Key 经过目标服务 hash 加密后放在 tgt 内部。

  2. 除了 Server Session Key 之外,tgt 内部最重要的信息就是 PAC,PAC 通常直接从 tgt 中复制。

  3. PAC 受 serverchecksum 和 privsvrchecksum 两个签名的保护:

    • privsvrchecksum :使用 krbtgt 服务账户 hash 进行签名

    • serverchecksum :从 krbtgt 服务账户 hash 进行签名替换为使用目标服务账户 hash 进行签名。

  4. Server Session Key 的作用出现在 tgs-req & tgs-rep。

ap-req & ap-rep

发送服务票据,服务器进行验证流程如下:

  1. 客户端接受到 tgs-rep 后,使用用户 Logon Session Key 解密被加密的 Server Session Key。

  2. 客户端使用 Server Session Key 加密时间戳,并和 st、以及其他一系列其他信息组成 ap-req 发送给服务器以访问目标服务。

  3. 服务器提前会在本地缓存服务账户 hash,使用服务账户 hash 解密 st 中被加密的 Server Session Key,并使用 Server Session Key 来验证客户端的加密时间戳,如果能解密成功,则客户身份验证成功

  4. 身份验证成功进入会话阶段。

  5. 服务器提取 st 的 pac 信息,并根据自身缓存的 acl 判断用户所具有的权限。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2261507.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Kotlin复习

一、Kotlin类型 1.整数 2.浮点 显示转换: 所有数字类型都支持转换为其他类型,但是转换前会检测长度。 toByte(): Byte toShort(): Short toInt(): Int toLong(): Long toFloat(): Float toDouble(): Double 不同进制的数字表示方法(为了提高…

12月17日作业

#include <myhead.h>int main(int argc, const char *argv[]) {int pipefd[2];char buff[1024] "hello world";char s[1024];if(pipe(pipefd)-1){perror("pipe");return -1;}//读端pipefd[0] 写端pipefd[1]pid_t pid fork();//创建子进程if(pid0){…

Shopee算法分析 - 算法分析二(与URL有关的Key)

http://blog.androidcrack.com/index.php/archives/39/ 在Unidbg文章中, 我们尝试过多次主动调用, 文中可以发现, 只有253b8c85 这个的key是不变的. Unidbg运行一遍,搜索运行下这个Key, 我们在下面的堆栈中, 可以看到memcpy的调用地址为0x0498ec Unidbg trace整个流程, 在010ed…

ChatGPT重大更新:新增实时搜索和高级语音

12月17日消息&#xff0c;据报道&#xff0c;OpenAI开启了第八天技术分享直播&#xff0c;对ChatGPT搜索功能进行了大量更新。 此次ChatGPT新增的功能亮点纷呈。其中&#xff0c;实时搜索功能尤为引人注目。OpenAI对搜索算法进行了深度优化&#xff0c;使得用户提出问题后&…

Day9 神经网络的偏导数基础

多变量函数与神经网络 在神经网络中&#xff0c;我们经常遇到多变量函数。这些函数通常描述了网络的输入、权重、偏置与输出之间的关系。例如&#xff0c;一个简单的神经元输出可以表示为&#xff1a; z f ( w 1 x 1 w 2 x 2 … w n x n b ) z f(w_1x_1 w_2x_2 \ldots…

windows和LINUX下校验文件的哈希值(MD5、SHA256)

可以通过两个文件的哈希值来对比两个文件是不是一模一样&#xff0c;有没有缺失 1、windows CertUtil -hashfile 文件路径 MD5 CertUtil -hashfile 文件路径 SHA256 2、Liunx 校验当前目录下所有文件 sha256sum . 校验指定文件名 sha256sum 文件名

使用beego操作数据库的简单web项目

1、beego介绍 Beego 是一个开源的、高性能的Go语言框架&#xff0c;用于快速开发RESTful API、Web应用、后端服务等各种类型的软件。它由国人Asta Xie创建&#xff0c;并得到了广泛的社区支持。Beego的设计理念是让开发者能够以最少的时间和代码量来完成Web应用的开发。 以下是…

IS-IS协议

IS-IS协议介绍 IS-IS&#xff08;Intermediate System to Intermediate System&#xff09;协议是一种链路状态的内部网关协议&#xff08;IGP&#xff09;&#xff0c;用于在同一个自治系统&#xff08;Autonomous System, AS&#xff09;内部的路由器之间交换路由信息。IS-I…

不良人系列-复兴数据结构(栈和队列)

个人主页&#xff1a;爱编程的小新☆ 不良人经典语录&#xff1a;“相呴相济 玉汝于成 勿念 心安” 目录 一. 栈(stack) 1. 栈的概念 2. 栈的常见方法 3.栈的模拟实现 ​编辑 二. 队列 1. 队列的概念 2. 队列的使用 2.1 队列的常见方法 2.2 队列的模拟实现 2.3 队列…

机器学习04-为什么Relu函数

机器学习0-为什么Relu函数 文章目录 机器学习0-为什么Relu函数 [toc]1-手搓神经网络步骤总结2-为什么要用Relu函数3-进行L1正则化修改后的代码解释 4-进行L2正则化解释注意事项 5-Relu激活函数多有夸张1-细数Relu函数的5宗罪2-Relu函数5宗罪详述 6-那为什么要用这个Relu函数7-文…

win服务器的架设、windows server 2012 R2 系统的下载与安装使用

文章目录 windows server 2012 R2 系统的下载与安装使用1 windows server 2012 的下载2 打开 VMware 虚拟机软件&#xff08;1&#xff09;新建虚拟机&#xff08;2&#xff09;设置虚拟机&#xff08;3&#xff09;打开虚拟机 windows server 2012&#xff08;4&#xff09;进…

241217-解决Ollama无法通过配置文件修改模型下载路径的方法

A. 常规修改下载模型路径的方法 Linux怎样设置ollama保存模型的路径&#xff1f; - 南门子的回答 - 知乎 B. 上述方法失效时的解决方案 Is there a way to change the download/run directory? Issue #680 ollama/ollama 具体来说也就是在ollama serve 启动之前&#xff…

戴森球计划新玩法!利用MOD和cpolar实现公网环境多人游戏

文章目录 前言1. 下载MOD2.配置cpolar内网穿透3. 主机开启联机3.1 玩家加入游戏 4. 配置固定的TCP端口5. 游玩体验 前言 《戴森球计划》不仅是一款融合了科幻冒险与经营管理元素的游戏&#xff0c;更是一个让玩家在浩瀚宇宙中尽情探索和创造的平台。在这个游戏中&#xff0c;你…

农田“智能管家”:道品科技农业移动式水肥一体机

一、农业移动式水肥一体机的兴起背景 &#xff08;一&#xff09;现代农业面临的挑战 在全球人口持续增长的大背景下&#xff0c;如今的粮食需求较以往有了大幅度增加。据相关统计数据显示&#xff0c;预计到 2030 年&#xff0c;全世界仍有近 6 亿人口长期食物不足。为了保障…

计算机进制的介绍

一.进制介绍 对于整数&#xff0c;有四种表示方式: 1&#xff09;二进制:0,1&#xff0c;满2进1。 在golang中&#xff0c;不能直接使用二进制来表示一个整数&#xff0c;它沿用了c的特点。 参考:Go语言标准库文档中文版 | Go语言中文网 | Golang中文社区 | Golang中国 //赋值…

3D Gaussian Splatting for Real-Time Radiance Field Rendering-简洁版

1. 研究背景与问题 传统的3D场景表示方法&#xff0c;如网格和点云&#xff0c;适合GPU加速的光栅化操作&#xff0c;但缺乏灵活性。而基于神经辐射场&#xff08;NeRF&#xff09;的表示方式&#xff0c;尽管质量高&#xff0c;但需要高成本的训练和渲染时间。此外&#xff0…

用ue5打开网址链接

需要用到 Launch URL 这个函数 字面意思就是打开填写的链接网页 这里填写的是百度&#xff0c;按下Tab键后就会打开百度的网页

电脑为什么会提示“msvcr120.dll缺失”?“找不到msvcr120.dll文件”要怎么解决?

电脑故障排查指南&#xff1a;揭秘“msvcr120.dll缺失”的真相与解决方案 在软件开发与日常维护的广阔天地里&#xff0c;遇到系统报错或文件缺失的情况可谓家常便饭。今天&#xff0c;我将带领大家深入探讨一个常见的系统提示——“msvcr120.dll缺失”&#xff0c;并揭秘其背…

Java:集合(List、Map、Set)

文章目录 1. Collection集合1-1. 迭代器遍历方式1-2. 通过for循环进行遍历1-3. forEach遍历 2. List集合2-1. ArrayList底层实现原理2-2. LinkedList底层实现原理 3. Set集合3-1. HashSet 底层实现3-2. LinkedHashSet 底层实现3-3. TreeSet 4. Collection集合->总结5. Map集…

4_使用 HTML5 Canvas API (3) --[HTML5 API 学习之旅]

4_使用 HTML5 Canvas API (3) --[HTML5 API 学习之旅] 1.缩放 canvas 对象 在 <canvas> 中缩放对象可以通过 scale 方法来实现。这个方法会根据提供的参数对之后绘制的所有内容进行缩放。下面是两个具体的示例&#xff0c;展示如何使用 scale 方法来缩放 canvas 上的对…