轻松理解 NTLM 协议工作流程

ntlm 协议在 windows nt 和 windows 2000 server(或更高版本)的工作组环境中使用(kerberos 用于域模式下)。

在 AD 域环境中,若需要验证 Windows NT 系统,必须使用 NTLM。与 Kerberos 相比,NTLM 认证过程更为简单。NTLM 采用挑战/响应(Challenge/Response)消息交换模式,以下是 NTLM 的认证流程:

轻松理解 NTLM 协议工作流程NTLM 认证协议可用于多种协议中,例如 HTTP、SMB 等。以下通过 HTTP 协议来说明其具体认证流程:

首先,我们需要选择一个目标,也可以自己搭建一个基于域的 401 认证服务。我这里选择了一个实际的环境进行测试,通常 Exchange 邮件服务器会有 EWS 接口,我们可以随意选择一个进行测试。

在 Bing 上使用语法搜索:

找一个使用 Exchange 搭建的邮件服务器,并且支持 HTTP,因为转包查看时,HTTPS 经过加密的包不太容易分析。我找到了一个:

轻松理解 NTLM 协议工作流程启动 Wireshark,然后访问上述链接,随机输入账号和密码,点击登录后,会得到一些 HTTP 数据包,如图:

轻松理解 NTLM 协议工作流程验证流程分为三步:第一步,获取服务器的基本信息,例如认证协议、服务器版本,如图:

轻松理解 NTLM 协议工作流程第二步,获取服务器返回给客户端的挑战值,如图:

轻松理解 NTLM 协议工作流程这个值在后面的数据校验中会使用,这里先不详细介绍。

第三步,根据前面获取的数据,组合后提交给服务器,在服务器端进行验证。

轻松理解 NTLM 协议工作流程这里的 NTProofStr 是一个用于数据验签的哈希值,确保前面获取的挑战和后面的数据是完整且未经修改的。

我们将上图中 NTLMv2 的响应值复制并处理如下:

最前面的 32 个字符就是验证数据完整性的哈希值,也就是 NTProofStr 的值,后面的数据中包含了一些服务器的信息,如图:

轻松理解 NTLM 协议工作流程这些数据是第三步的请求阶段,即客户端提交给服务器的数据,服务器将使用这些数据进行验证,判断是否通过。

验签哈希如何产生?从上面我们看不到账号密码信息在哪里发挥作用,下面我们来看看具体账号密码在哪里被使用,以及在哪里发挥作用。

在内网渗透时,我们经常会捕获本地密码,本地存储的哈希就是用户密码经过一系列加密后的结果,具体加密方式如下:

函数解释:hex 用于将字符串转换为十六进制值、unicode 用于将字符串转换为双字节字符串、md4 为 md4 哈希。

轻松鲨 轻松鲨

与AI连续对话聊天提问,多场景50+文案写作模板,AI智能生成思维导图

轻松鲨 32 查看详情 轻松鲨

以下是用 Python 编写的关键函数代码示例:

hex 函数:

def str_to_hex(s):      return ' '.join([hex(ord(c)).replace('0x', '') for c in s])

转双字节函数:

def hex_to_unicode(hex_str):      hex_str_ = hex_str.replace(" ","00")+"00"      return hex_str_

md4 哈希函数:

from Crypto.Hash import MD4def str_to_md4(str_):      m = MD4.new()      m.update(str_)      return m.hexdigest()

仅有密码是不够的,如何将用户名和域信息用上呢?这里涉及到一个 NTLMv2 HASH,具体算法如下:

关键函数:upper 用于将字符串全部转换为大写字母、md5 用于将 NTLM 的哈希作为盐,对用户名和域组合的信息进行 md5 哈希。

md5 哈希函数:

import hmacimport hashlibdef str_to_hmac_md5(passwd_,salt_):      h_md5 = hmac.new(salt_, passwd_, hashlib.md5).hexdigest()      return h_md5

从上面的过程来看,最后得到的 NTLMv2 HASH 包含了账号、密码和域的信息,如果任何一个因素有问题,整个验证就不会成功,那么这个哈希在后面如何使用呢?

服务器如何验证客户端提交的信息?在最后一步,客户端提交的信息包括:

签名哈希 NTProofStr 用于验证数据完整性,数值为:c9ce34e95466b7e956dd63da0b17e2e8

还有一串数据,在上面已经提供,前面的 32 位字符串就是上面的签名哈希,去掉之后就是服务器相关的数据,提取出来如下:

在之前第二步时,获得了一个挑战值: e8fd1257ab09ae57

到这里,所有需要的数据都有了,那么这些数据之间有什么关系呢?主要是签名的获取算法,公式如下:

理解起来也很简单,就是将第二步的挑战值和服务器的数据连接起来,使用包含账号密码域信息的哈希作为盐进行 md5 哈希后的结果就是签名值,我们用一个小巧的计算器来计算一下:

轻松理解 NTLM 协议工作流程

以上就是轻松理解 NTLM 协议工作流程的详细内容,更多请关注创想鸟其它相关文章!

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

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年11月7日 19:01:01
下一篇 2025年11月7日 19:06:51

相关推荐

  • Go 语言中字符串切片与换行符处理的惯用方法

    本文旨在阐明 Go 语言中字符串切片(substring)的正确使用方法,特别是如何惯用地处理从输入流中读取的字符串末尾的换行符。我们将深入探讨 Go 字符串和切片的工作原理,纠正常见的 C 语言思维误区,并提供简洁高效的代码示例,帮助开发者避免不必要的复杂操作,实现优雅的字符串处理。 1. Go …

    好文分享 2025年12月15日
    000
  • Golang使用WSL环境搭建实践方法

    首先安装WSL并配置Ubuntu发行版,通过wsl –install命令启用功能并安装Linux系统;随后更新系统并下载Go语言包,解压至/usr/local目录,配置PATH、GOPATH环境变量并生效;接着安装VS Code及Remote-WSL插件,通过code .命令在WSL中打…

    2025年12月15日
    000
  • Golang模块初始化后快速构建示例

    初始化Go模块后编写简单程序并添加外部依赖。使用go mod init创建模块,编写main.go并运行go run输出Hello, Go Modules!引入github.com/google/uuid时,Go自动下载依赖并更新go.mod和go.sum文件。 使用Golang模块(Go Modu…

    2025年12月15日
    000
  • GolangWeb开发中的安全防护实践

    答案:Golang Web安全需多维度防护,从输入校验、XSS/SQL注入防范,到身份认证、权限控制、依赖管理等全方位加固。具体包括使用html/template防XSS,预编译语句防SQL注入,JWT或Session配合安全配置实现认证,RBAC/ABAC进行细粒度授权,通过govulncheck…

    2025年12月15日 好文分享
    000
  • Go 语言:编译型语言及其底层原理

    Go 语言是一种编译型语言,它将源代码直接编译成特定平台的可执行文件,无需额外的运行时环境或虚拟机。其高效的编译速度和生成独立可执行文件的特性,使其在系统级编程和服务器端开发领域具有显著优势。 Go 语言的设计目标是提供一种高效、简洁、可靠的编程语言,特别适用于构建大型分布式系统。与解释型语言(如 …

    2025年12月15日
    000
  • Go 语言是解释型语言还是编译型语言?

    Go 语言是一种编译型语言,它直接将源代码编译成目标机器上的机器码,生成可独立执行的二进制文件,无需任何额外的运行时环境或依赖。Go 编译器以编译速度快而闻名,并支持多种操作系统和架构。 Go 语言的设计目标之一就是提供一种高效且易于部署的编程语言。为了实现这一目标,Go 语言采用了编译型模型,这意…

    2025年12月15日
    000
  • Go 语言是解释型还是编译型?深入理解 Go 的编译过程

    本文旨在解答 Go 语言的编译方式,明确 Go 语言属于编译型语言,而非解释型语言。Go 编译器能够生成完全独立的、无需额外运行时环境的可执行文件,并深入探讨了 Go 编译器的特性、支持的架构以及跨平台编译的便捷性,帮助读者更全面地理解 Go 语言的底层机制。 Go 语言是一种编译型语言,它通过编译…

    2025年12月15日
    000
  • Go 语言是解释型还是编译型?深入理解 Go 编译原理

    Go 语言是一种编译型语言,它将源代码直接编译成机器码,生成可独立执行的二进制文件。这意味着无需任何额外的运行时环境或依赖库,即可在目标平台上运行 Go 程序。Go 编译器以其编译速度快而闻名,并且支持多种操作系统和硬件架构,使其成为构建高性能、可移植应用程序的理想选择。 Go 编译器的架构 Go …

    2025年12月15日
    000
  • Google App Engine Go运行时搜索功能实现指南

    本文旨在为Google App Engine Go运行时提供搜索功能缺失时的解决方案。核心方法包括构建一个RESTful Python%ignore_a_1%服务,由Go应用通过urlfetch进行代理调用,实现数据的索引、查询等操作;或利用第三方搜索服务快速集成。文章将详细探讨两种方案的实现细节、…

    2025年12月15日
    000
  • Go 语言中高效打乱数组的教程

    在 Go 语言中,对数组进行随机排序(打乱)是一个常见的需求。与 Python 等语言不同,Go 标准库并没有直接提供 shuffle 函数。然而,我们可以利用 Fisher-Yates 洗牌算法来实现高效且简洁的数组打乱功能。 本文将深入探讨如何在 Go 语言中实现 Fisher-Yates 算法…

    2025年12月15日
    000
  • Go语言:编译型语言的深度解析与系统级编程能力

    Go语言是一种高效的编译型语言,直接将源代码编译为针对特定架构的自给自足的机器码可执行文件,无需外部运行时或库。它支持多平台编译,以其快速编译和部署能力,成为系统级编程的有力替代者,提供了卓越的性能和部署便利性。 Go语言的编译本质 go语言的核心特性之一是其作为一种编译型语言的定位。与解释型语言(…

    2025年12月15日
    000
  • Go 语言中高效打乱数组的指南

    本文旨在介绍在 Go 语言中如何高效地打乱数组(或切片)的顺序。 重点讲解了 Fisher-Yates shuffle 算法的 Go 语言实现,并提供了避免额外内存分配的优化方案。通过示例代码和详细解释,帮助开发者掌握在 Go 语言中实现数组随机排序的技巧,并理解其背后的原理。 在 Go 语言中,并…

    2025年12月15日
    000
  • Golang配置GOPATH与GOROOT详细指南

    正确配置GOROOT和GOPATH是Go开发的基础。1. GOROOT指向Go安装目录,如Linux/macOS默认为/usr/local/go,Windows为C:Go,安装后通常无需手动设置;2. GOPATH为工作区路径,推荐设为$HOME/go,包含src、pkg、bin三个子目录;3. 需…

    2025年12月15日
    000
  • Golang控制语句if else用法详解

    Go语言的if else结构强调简洁与明确,无需条件括号且强制大括号,支持初始化语句与局部作用域,结合卫语句、函数拆分和switch优化可读性,体现其错误处理优先与代码清晰的设计哲学。 说起Go语言的条件判断, if else 自然是绕不开的基石,它简单直接,却又有着一些Go特有的“小心思”。本质上…

    2025年12月15日
    000
  • Golang在容器化部署中的实践方法

    Golang因静态编译、低开销和高并发优势,成为容器化部署的理想选择。其独立二进制文件无需外部运行时,可构建极小镜像(如基于scratch或alpine),显著提升启动速度与安全性,降低资源消耗。多阶段构建能有效分离编译与运行环境,结合CGO_ENABLED=0、-ldflags=”-s…

    2025年12月15日
    000
  • Golang跨平台开发环境搭建指南

    首先安装Go运行时并配置环境变量,然后选择合适的开发工具如VS Code或GoLand,接着通过设置GOOS和GOARCH实现跨平台编译,最后使用Go Modules管理项目依赖并遵循标准目录结构组织代码。 Go语言(Golang)以其简洁的语法、高效的编译速度和天然支持并发的特性,成为现代软件开发…

    2025年12月15日
    000
  • Go语言高效跨平台编译实践:基于GOOS与GOARCH

    Go 1.5版本显著简化了跨平台编译流程。开发者现在只需设置GOOS和GOARCH环境变量,即可轻松为不同操作系统和架构生成二进制文件,无需复杂的make.bash脚本或第三方工具。本文将详细介绍如何利用这一内置功能,实现高效、便捷的Go应用跨平台构建,帮助您快速掌握Go语言的强大跨平台能力。 Go…

    2025年12月15日
    000
  • 深入探讨:协程与续体在Web编程中的未竟之路

    协程(Python)和续体(Ruby)曾被视为解决Web编程中状态管理难题的优雅方案,通过模拟线性执行流简化复杂请求序列。然而,随着AJAX技术普及,Web应用转向异步、事件驱动模式,其线性、单流的优势不再适应多并发、独立请求的现代架构,导致它们未能广泛应用于主流Web开发,焦点转向了更灵活的事件处…

    2025年12月15日
    000
  • Golang开发环境安装与配置教程

    Go语言安装需下载对应系统包并配置环境变量。Windows用户运行.msi安装,macOS可用.pkg或Homebrew,Linux则解压.tar.gz至/usr/local。随后设置GOROOT、GOPATH及PATH,使go命令可用。通过go version和go env验证安装与配置。创建项目…

    2025年12月15日
    000
  • Go语言跨平台路径操作指南:正确使用path与filepath包

    在Go语言中处理跨平台文件路径时,path.Dir函数默认使用正斜杠/作为路径分隔符,导致在Windows系统上处理反斜杠路径时行为不符预期。本教程将详细介绍如何利用path/filepath包中的filepath.Dir函数,实现操作系统感知的路径操作,确保程序在不同平台下都能正确解析文件目录,避…

    2025年12月15日
    000

发表回复

登录后才能评论
关注微信