当前位置:网站首页>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]所创,转载请带上原文链接,感谢
边栏推荐
- Utility class functions (continuous update)
- STM32F030F4P6兼容灵动微MM32F031F4P6
- September 3, 2020: naked writing algorithm: loop matrix traversal.
- 2020-08-14:数据任务的执行引擎用的哪些?
- Practice of Xiaoxiong school development board: real equipment access of smart street lamp sandbox experiment
- 2020年新规,微信封号怎么快速解除?
- How to add modules to nginx image?
- C calls SendMessage to refresh the taskbar icon (the icon does not disappear at the end of forcing)
- Configuration of AP hotspot on xunwei-imx6ull development board
- Google browser realizes video playback acceleration function
猜你喜欢
移动端像素适配方案
Js数组-数组的用法全在这里(数组方法的重构、数组的遍历、数组的去重,数组的判断与转换)
python3操作Jenkins模块api
Getting started with varhart xgantt
Stickinengine architecture 11 message queue
Stickinengine architecture 12 communication protocol
Benefits and functions of auto maintenance app development
Cloudquery v1.2.0 release
应用层软件开发教父教你如何重构,资深程序员必备专业技能
Markdown tricks
随机推荐
移动端像素适配方案
vue3 新特性
Bluetooth broadcast chip for Shanghai giant micro
Characteristics of magnetic memory chip STT-MRAM
How does LeadTools detect, read and write barcodes
Gantt chart grouping activities tutorial
2020-08-15: under what circumstances should data tasks be optimized?
JS string - string string object method
JVM class loading mechanism
图像处理工具包ImagXpress使用教程,如何查看事件
jenkins pipline stage 设置超时
Stm32f030k6t6 compatible replacement smart mm32f031k6t6
ado.net and asp.net The relationship between
Jenkins入门(二)声明式流水线Jenkins Pipeline
Win7 AppCrash (solution)
August 18, 2020: introduce Mr process?
打工人好物——磨炼钢铁意志就要这样高效的电脑
Summary of common SQL statements
How to write plug-in code of small program mall system? How to use code to check whether the plug-in is successfully added?
The 4th China BIM (digital construction) manager Summit Forum will be held in Hangzhou in 2020