当前位置:网站首页>Three steps to understand Kerberos Protocol easily
Three steps to understand Kerberos Protocol easily
2020-11-06 22:38:00 【Official account Bypass】
Kerberos It's an authentication protocol , It serves as a trusted third-party authentication service , By using symmetric encryption technology for the client / Server applications provide strong authentication . In domain environment ,AD Domain use Kerberos Protocol verification , Be familiar with and master Kerberos Protocol is the basis of learning domain penetration .
Kerberos Three main roles in the protocol :
1. Access to the service Client
2. serviceable Server
3.KDC: Key distribution center , It is installed on the domain controller by default
AS: Authentication service
TGS: Ticket granting service
Kerberos Protocol authentication process :
The agreement can be divided into three steps : One is to obtain the bill permit , The second is to obtain service license bills , Third, access to services .
First step : Get a note permit note
KRB_AS_REQ: Used to direct to KDC request TGT
When the user enters the domain user and password on the client side , The client converts the user's password to hash As an encryption key , Encrypt the timestamp as request credentials .
cipher: Encrypted timestamp , That is, the current time of the client and the user's hash The result of encryption
KRB_AS_REQ The packets are as follows :
KRB_AS_REP: Used by KDC Pass on TGT
Upon receipt of the request ,KDC from AD Domain database to find the user's hash Decrypt the timestamp to verify the user's identity . If the timestamp is within the allowed time range , Then it will generate a session key (Session key), With AS_REP The packet responds .
AS_REP Include information :
ticket: Use krbtgt hash encryption , Include user name / Session key and expiration time .
enc-part: Using the user hash encryption , Contains the session key /TGT Expiration time and random number ( Anti replay )
KRB_AS_REP The packets are as follows :
The second step : Get a service license ticket
KRB_TGS_REQ: Use TGT towards KDC request TGS
The client gets TGT And user key encryption enc-part
, Using the user hash Decrypt enc-part
Get session key (Session key), Then use the session key to change the user name / The timestamp is encrypted , Generate authenticator and TGT Send to TGS.
ticket: It's actually a picture of TGT, The client doesn't have krbtgt hash, So we can't decrypt TGT.
KRB_TGS_REQ The packets are as follows :
KRB_TGS_REP: adopt KDC Pass on TGS
TGS received KRB_TGS_REQ After the request , Use krbtgt hash Decrypt ticket Get session key (Session key), Then decrypt it with the session key authenticator Get the user name and timestamp for authentication . After confirming the information , Create a service session key (Service Session key).
ticket: Encrypt with the corresponding service key , Contains the service session key / user name / Expiration time and other information , It's essentially a piece of ST(Service Ticket).
enc-part: Contains the service session key encrypted with the session key (Service Session key)
KRB_TGS_REP
The packets are as follows :
The third step : Get services
KRB_AP_REQ: Use TGS, The service authenticates the user
The client already has a valid TGS Can interact with services , Decrypt with session key enc-part, obtain Service session key (Service Session key), Put the user name / Information such as timestamps uses the service session key (Service Session key) To encrypt , Get new Authentication.
KRB_AP_REP: Used by a service to identify itself to a user
The server receives the request , Use your own hash Decrypt TGS Get the service session key (Service Session key) And authorized user information , Then decrypt it using the service session key Authentication, Compare user names and timestamps , If there are mutual verification marks , The client sends the session key to the encrypted service with a timestamp , The client decrypts the timestamp and verifies the server , And then you start asking for services .
This article is from WeChat official account. - Bypass(Bypass--).
If there is any infringement , Please contact the [email protected] Delete .
Participation of this paper “OSC Source creation plan ”, You are welcome to join us , share .
版权声明
本文为[Official account Bypass]所创,转载请带上原文链接,感谢
边栏推荐
- Exclusive interview of guests at | 2020 PostgreSQL Asia Conference: Wang Tao
- 2020-08-14:数据任务的执行引擎用的哪些?
- What grammar is it? ]
- How does LeadTools detect, read and write barcodes
- vue3 新特性
- Stm32f030f4p6 compatible with smart micro mm32f031f4p6
- The first choice for lightweight GPU applications is the NVIDIA vgpu instance launched by Jingdong Zhilian cloud
- How to use Gantt chart layers and filters
- 南京标志设计,logo设计公司
- 条形码识别器Dynamsoft Barcode Reader v7.5全新上线!
猜你喜欢
LEADTOOLS如何检测,读取和写入条形码
VARCHART XGantt如何在日历上表示工作日
【涂鸦物联网足迹】涂鸦云平台全景介绍
Es create a new index database and copy the old index library, practice pro test effective!
Image processing toolkit imagexpresshow to view events
Epu360: all the H5 templates you want are here, e-book, big turntable, red envelope rain, questionnaire survey
[graffiti Internet of things footprints] panoramic introduction of graffiti cloud platform
NAND FLASH的接口控制设计
上海巨微专用蓝牙广播芯片
Application of UHF RFID medical blood management system
随机推荐
Bluetooth broadcast chip for Shanghai giant micro
python3操作Jenkins模块api
python3操作gitlab
The Interpreter pattern of behavior pattern
谈了多年的数字化转型,为什么还有很多企业依然“口头管理”
Unexpected element.. required element
Countdown | 2020 PostgreSQL Asia Conference - agenda arrangement of Chinese sub Forum
STM32F030F4P6兼容灵动微MM32F031F4P6
jenkins pipline stage 设置超时
STM32F030C6T6兼容替换MM32SPIN05PF
WebAPI接口设计:SwaggerUI文档 / 统一响应格式 / 统一异常处理 / 统一权限验证
Markdown tricks
高速公路二维码定位报警系统
FreeSWITCH视频会议“标准”解决方案
How to create an interactive kernel density chart
Characteristics of magnetic memory chip STT-MRAM
New features of vue3
Image processing toolkit imagexpresshow to view events
Design of NAND flash interface control
Stm32f030c6t6 compatible to replace mm32spin05pf