
网问答>>MTProto ,telegram的端到端加密技术之一:Architecture概述(翻译)


MTProto ,telegram的端到端加密技术之一:Architecture概述(翻译)
时间:2025-07-23 18:43:40
MTProto ,telegram的端到端加密技术之一:Architecture概述(翻译)

MTProto,Telegram的端到端加密技术之一:Architecture概述(翻译)MTProto是Telegram为防止监控而实现的端到端加密协议。以下是该协议架构的概述翻译:一个简单的总结(和ISO/OSI七层协议栈对照)应用层:顶层RPC应用接口表示层:类型语言(Type Language)会话层:MTProto会话传输层:MTProto传输层,MTProto模糊(obfuscation)层(可选),以及传统的传输层协议MTProto协议运行在传输层协议(如TCP、UDP)和HTTP/HTTPS/WS/WSS协议之上。协议设计概述MTProto协议是为移动端应用接入服务器而设计的,注意网页端并不属于这个类型。协议划分为虚拟的三个独立的组件:顶层组件(RPC查询语言/API):定义了API查询和回复如何被转化为二进制信息。加密(鉴权)层:定义了在传输层发送信息之前信息是如何被加密的。传输组件:定义了客户端和服务器在已有的网络协议(如HTTP、HTTPS、TCP、UDP、WS、WSS)上发送信息的方法。注:Telegram使用MTProto 2.0,1.0版本已经放弃维护。这些名词在后续有机会的话会逐一解释简单的组件描述顶层组件(RPC查询语言/API)从顶层组件的角度看,客户端和服务器在一个会话(session)中交换消息(message)。一个会话依附于客户端设备(准确来说是应用)而不是一个特定的websocket/http/tcp/https连接。每个会话依附于一个已经完成了鉴权的User Key ID。可以打开与一个服务器的多个连接。连接是双工的,即消息可以从连接的任意一端发出。一个查询的回应可以不从同一个连接发回(但一般如此),但必定在同一个会话中发回。在UDP协议中,一个查询的回应可以从和查询的目的IP不一样的IP地址发出。消息有多种类型:RPC调用(客户端-服务器)RPC回应(服务器-客户端)确认接收消息(或一坨消息的状态的通知)消息状态查询一坨消息/容器(一个容器容纳多条信息,需要在一个http连接上同时发送多个RPC调用;另一个容器也许也支持gzip)从底层协议的角度看,一条消息是一条满足4字节或16字节边界对齐的二进制数据流。信息的前几个域是固定的,被加密/鉴权系统所使用。每条消息,无论是在容器中的还是单独的,都由以下几部分组成:消息ID(64bit)消息在会话中的序列号(32bit)消息主体(body)长度(32bit)消息主体(长度为4字节的倍数)当消息(单独或者在容器中)被发送之后,会被加上一个内部头(internal header)。被加密之后,还会被加上一个外部头(external header)。消息主体一般含有一个32bit的消息类型和一些类型依赖的参数。特别地,每个RPC函数都有一个相应的消息类型。所有的数字一般都用小端法书写,但在RSA、DH中使用的很大的数字(2048bit)一般用大端法格式,因为OpenSSL库就这样。鉴权和加密在一条消息在其他传输层协议之上被发送之前,它以一种特定方式被加密,并且会被加上一个外部头,包含一个64bit的用户Key ID(唯一确定用户和服务器之间的一对鉴权Key)和一个128bit的消息Key。一个用户Key和一个消息Key定义了一个256bit的Key,被用来使用AES-256加密方式加密消息。注意一条消息被用于加密的最初部分包含了变量(会话,消息ID,序列号,服务器salt),会很明显地影响消息Key(以及AES Key)。消息Key被定义为SHA加密之后的消息主体的中间的128bit,也包括了填充字节,前面的部分是鉴权Key当中拿来的32字节。多条消息的整体作为一整条消息被加密。一个客户端应用要做的第一件事就是创建一个鉴权Key,一经运行,几乎永不更改。协议最原则性的一个缺陷就是如果一个被动拦截消息而占有了鉴权Key(比如偷走了一台设备)的入侵者就能解密所有拦截了的消息,但这不是什么大问题(因为偷了设备之后本来不用解密就能获得所有信息)。然而,以下的步骤能克服这个弱点:会话Key用Deffie-Hellman协议生成,和鉴权和消息Key链接去选择AES的参数。创建这些,一个客户端在创建会话之后需要做的第一件事就是向服务器发送一个特殊的RPC查询(“generate session key”),服务器回复,接下来的所有消息也都会用这个会话Key加密。(用文本密码)保护好客户端设备上的Key。这个密码不存储在内存里,用户每次启动应用(或者更频繁地)手动输入。用户设备上缓存或存储的数据也可以被用一个鉴权Key加密的方式保护,但是这个Key也需要被密码保护。时间同步如果客户时间和服务器时间差别太多,一个服务器就可能开始忽略客户端消息,或者反过来,因
时间:2025-07-23 18:43:41
本类最有帮助
- 关于贵巢床垫,听说其环保性能怎么样呢?
- 喜元帅瓷砖属于几线品牌?
- 长安的荔枝被禁播了么
- 这是边牧串吗?
- 云彩石地坪漆有什么优势?家里能用吗?
- 针对一般家庭装修,云彩石品牌提供怎样的组合方案?
- 听说藏天参和普通人参存在区别,为什么它的价格会更
- 叶良柱为什么选择给家具涂木蜡油而不是化学漆呢?
- 王浩输给过谁
- 小人全部滚。。。别想合好。。一个字穷?
- 包头包钢友谊宾馆酒店介绍
- 为啥应该感谢别人帮忙,但是有些人是要求别人感谢他
- 感恩是怎么来的,为啥有的人劝人目的是别人必须感谢
- 关于央心心理咨询,目前它的收费贵不贵呢?
- 关于央心心理咨询,第一次体验目前感觉如何?
- 对于央心心理咨询APP,收费标准是怎样的?
- 关于央心心理咨询,听说有线下机构分布吗?
- 二把手做好二把手
- 他对我有意思吗?
- 我喜欢你和能做我女朋友吗哪个正式有仪式感?
- 教师节写给教师的贺卡祝福贺词
- 以前很珍贵的应用,不小心删了,然后又忘了他的名字
- 以前很珍贵的赚钱应用,不小心删了,然后又忘了他的
- 最近麻烦事多,工作干不下去做不开心,新工作又不可
- 为什么我总是被用别人的咒骂语才能把自己隐藏到人群
- 一个未婚大龄女性,被一个已婚有子女的女人骂绝子绝
- 汽修兄弟们,有没有轻巧还贼拉带劲的电动扳手?
- 新国标电动车能解限速吗
- 光伏发电组成部分?
- 光伏板最多串联多少组?
- 光伏板之间怎么连接?
- 炫潮隐形车衣怎么样?
- 炫潮隐形车衣值得购买吗?
- 隐形车衣炫潮怎么样?
- 汽车解码器进不到系统是什么原因?
- 自由光喇叭什么牌子
- 炫潮品牌隐形车衣质量怎么样?
- 简单回答一下发动机电脑控制点火系统的工作过程
- 2014年A8发动机电脑版多少钱?
- 鉴别本田割草机真假识别
- 关于店商豹,它是怎么赚钱的?
- 当前银监会能否帮助协商还款
- 重庆丰都中学高考成绩亮眼
- 广东岭南职业技术学院有几个校区?地址分别在哪?
- 马明义平凉一中校长
- 广东岭南职业技术学院从广州天河区如何到达清远校区
- 长沙市通航中等职业学校是中专还是大专?可以学哪些
- 手机第一次充电充多长时间好?
- 怎么刷机?
- 王老师买粉笔用去29元7角,买墨水用去57元9角,她付
网问答为提供知识和解答各类疑难的平台,目标是做到有问必答解决您遇到的各类问题.本站内容均为网友发表,并不代表本站立场!
Copyright © 2008-2013 www.wangwenda.com All rights reserved.冀ICP备12000710号-1
投诉邮箱:
