当前位置:网站首页>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]所创,转载请带上原文链接,感谢
边栏推荐
- Git remote library rollback specified version
- Points to be considered when deleting mapping field of index in ES
- Unexpected element.. required element
- List to map (split the list according to the key, and the value of the same key is a list)
- vue3 新特性
- 轻量型 GPU 应用首选 京东智联云推出 NVIDIA vGPU 实例
- Image processing toolkit imagexpresshow to view events
- 关于DevOps的七大误解,99%的人都曾中过招!
- MRAM高速缓存的组成
- How to add modules to nginx image?
猜你喜欢
[graffiti Internet of things footprints] panoramic introduction of graffiti cloud platform
Web API interface design: swaggerui document / unified response format / unified exception handling / unified authority verification
Event monitoring problem
What are the highlights of Huawei mate 40 series with HMS?
The memorandum model of behavior model
To solve the problem that the data interface is not updated after WPF binding set
Reserved battery interface, built-in charge and discharge circuit and electricity meter, quickly help easily handle hand-held applications
迅为iMX6开发板-设备树内核-menuconfig的使用
Unexpected element.. required element
Logo design company, Nanjing
随机推荐
STM32F030K6T6兼容替换灵动MM32F031K6T6
关于DevOps的七大误解,99%的人都曾中过招!
迅为-iMX6ULL开发板上配置AP热点
预留电池接口,内置充放电电路及电量计,迅为助力轻松搞定手持应用
Gantt chart grouping activities tutorial
Utility class functions (continuous update)
The first choice for lightweight GPU applications is the NVIDIA vgpu instance launched by Jingdong Zhilian cloud
Using JSON webtoken (JWT) to generate token in nodejs
Unexpected element.. required element
图像处理工具包ImagXpress使用教程,如何查看事件
How does LeadTools detect, read and write barcodes
Markdown tricks
Method of code refactoring -- Analysis of method refactoring
#JVM 类加载机制
Common mathematical basic formulas of recursive and backtracking algorithms
三步轻松理解Kerberos协议
September 3, 2020: naked writing algorithm: loop matrix traversal.
WebAPI接口设计:SwaggerUI文档 / 统一响应格式 / 统一异常处理 / 统一权限验证
2020-08-20: the difference between go and python?
The use of Xunwei imx6 development board device tree kernel menuconfig