首页 > 动态中心 > 技术文章  >  正文

谁家的加密密钥,写死在代码里?

2023-06-15 00:00:00

文章摘要:系统设计,协议先行。大部分人不了解协议的设计细节,更多使用已有协议进行应用层设计,例如:使用HTTP,设计 get/post/cookie 参数,以及json包格式;使用dubbo,而不用去深究内部的二进制包头包体细节;无论如何,了解协议设计的原则,对深入理解系统通信非常有帮助。一、协议的分层设计所谓“协议”,是双方共同遵守的规则,例如:离婚协议,停战协议。协议有语法、语义、时序三要素:语法,即数

系统设计,协议先行。

大部分人不了解协议的设计细节,更多使用已有协议进行应用层设计,例如:

  • 使用HTTP,设计 get/post/cookie 参数,以及json包格式;
  • 使用dubbo,而不用去深究内部的二进制包头包体细节;

无论如何,了解协议设计的原则,对深入理解系统通信非常有帮助。

一、协议的分层设计

所谓“协议”,是双方共同遵守的规则,例如:离婚协议,停战协议。协议有语法、语义、时序三要素:

  • 语法,即数据与控制信息的结构或格式;
  • 语义,即需要发出何种控制信息,完成何种动作以及做出何种响应;
  • 时序,即事件实现顺序的详细说明;

画外音:后文主要讲语法设计。

协议设计通常分为三层:应用层协议、安全层协议、传输层协议。

下面分别看下这三层的协议应该如何选型。

二、应用层协议设计

应用层协议选型,常见的有三种:文本协议、二进制协议、流式XML协议。

(1) 文本协议

文本协议是指“贴近人类书面语言表达”的通讯传输协议,典型的协议是HTTP协议,一个HTTP协议的请求报文样例如下:

GET / HTTP/1.1
User-Agent: curl
Host: musicml.net
Accept: */*

文本协议的特点是:

  • 可读性好,便于调试;
  • 扩展性较好,能通过key:value扩展;
  • 解析效率不高,一行一行读入,按照冒号分割,解析key和value;
  • 对二进制不友好 ,比如语音/视频等;

(2) 二进制协议

二进制协议即binary协议,典型是IP协议,以下是IP协议的一个图示:

二进制协议一般包含:一般包含:

  • 定长包头;
  • 可扩展变长包体;
  • 一般每个字段有固定的含义,以IP协议为例,前4个bit表示协议版本号(Version);

二进制协议的特点是:

  • 可读性差,难于调试;画外音:打日志一般需要一个toString()函数增强可读性。
  • 扩展性不好,如果要扩展字段,旧版协议就不兼容了,所以设计时一般会有一个Version字段;
  • 解析效率超高,几乎没有解析代价,二进制流的每个字段表示固定含义;
  • 天然支持二进制流 ,比如语音/视频;

这是一个典型的16字节二进制定长包头的例子:

//sizeof(cs_header)=16
struct cs_header {
  uint32_t version;
  uint32_t magic_num;
  uint32_t cmd;
  uint32_t len;
  uint8_t data[];
}__attribute__((packed));

其中:

(1)前4个字节表示版本号version;

(2)接下来4个字节表示魔法数字magic_num,用来解决数据错位或丢包问题;

画外音:例如,约定好魔法数字是0x01020304,收到的报文,魔法数字匹配,认为是正常报文,否则认为是报文异常,断开连接。

(3)接下来4个字节表示命令号command,不同的命令号对应不同的变长包体;

(4)最后4个字节表示包体长度length,以确定变长包体有多少字节;

这是一个实际的二进制变长包体:

message CUserLoginReq {
  optional string username = 1;
  optional string passwd = 2;
}

message CUserLoginResp {
  optional uint64 uid =1;
}

它使用的是Google的Protobuf协议,容易看到:

  • 请求报文传入的是用户名与密码;
  • 响应包返回的是用户的uid;

PB是很流行的二进制变长包体协议,其优点为:

  • 通用,可以生成C++、Java、PHP等多语言代码;
  • 自带压缩功能;
  • 对二进制友好;
  • 在工业界已广泛应用;画外音:Google出品,必属精品。

流式XML协议流式XML似乎是文本协议的一个特例,亦可以单独作为一类。例如:xmpp就是典型的流式XML协议,下面是xmpp协议的一个典型报文:

<message
to=’romeo@example.net’
from=’juliet@example.com’
type=’chat’
xml : lang=’en’>
<body>Wherefore art thou, Romeo?</body>
</message>

从xml标签中大致可以判断这是一个romeo发给juliet的聊天消息。

XML协议有几个特点:

  • 可读性好,扩展性好,这是XML的特性;
  • 解析代价超高,需要进行dom树分析;
  • 有效数据传输率超低,有大量的标签;
  • 对二进制不友好 ,比如语音/视频等;

三、安全层协议设计

安全层协议设计,除了使用SSL,自行实现的话,常见的又有以下三种方案。

画外音:SSL秘钥管理是个问题。

(1) 固定密钥

服务端和客户端约定好一个密钥,同时约定好一个加密算法(例如:AES),每次客户端发送报文前,就用约定好的算法,以及约定好的密钥加密再传输,服务端收到报文后,用约定好的算法,约定好的密钥再解密。

画外音:安全性低,安全性基于程序员的职业操守。

(2) 一人一密

简单来说,就是一个人的密钥是固定的,但是每个人之间又不同。常见的实现方式是:

  • 固定加密算法;
  • 加密秘钥使用“用户的某一特殊属性”,比如用户uid、手机号、qq号、用户密码等;

(3) 一次一密

即动态密钥,一Session一密钥的安全性更高,每次会话前协商密钥。密钥协商的过程要经过2次非对称密钥的随机生成,1次对称加密密钥的随机生成,具体详情这里不展开。

四、传输层协议设计

可选的协议有TCP和UDP,现在基本都是使用TCP,有了epoll等技术后,多连接就不是瓶颈了,单机几十万链接没什么问题。[来源:架构师之路]

上一篇 : 企业有必要安装文件加密软件吗?加密软件选购指南
  • 相关推荐
  • CAD图纸怎么加密?CAD图纸加密攻略:五大加密防泄密技巧

    CAD图纸作为企业设计与创新的核心资产,其安全性至关重要。为有效防止图纸被非法复制、篡改或泄露,掌握CAD图纸加密技巧成为企业信息安全防护的关键。以下五大加密防泄密技巧,将助您构建坚不可摧的数据保护屏障,确保图纸信息的安全与完整,让您的创意成果得到最坚实的守护。1、使用洞察眼MIT系统系统支持透明加密技术,用户无需改变...

    2024-10-21 10:48:05
  • 企业文件加密防泄密必备,2024必备!六款企业防泄密软件精选

    在数字化时代,企业数据的安全防护至关重要。随着信息泄露风险的日益增加,企业文件加密防泄密已成为企业安全管理的关键环节。2024年,我们精选了六款高效、实用的企业防泄密软件,旨在为企业提供全方位的数据安全保障。这些软件不仅具备强大的加密功能,还能实时监控和预警潜在的安全风险,助力企业构建更加稳固的数据安全防线。1、洞察眼...

    2024-10-21 10:22:55
  • 企业必备!2024电脑加密软件精选:八款宝藏工具大放送!

    在数字化浪潮汹涌的2024年,企业数据安全面临着前所未有的挑战。为了守护企业核心资产,电脑加密软件成为了不可或缺的防线。本次精选八款宝藏级电脑加密工具,它们各具特色,从数据加密、行为监控到权限管理,全方位守护企业数据安全。让我们一同探索这些强大的加密软件,共同迎接数据安全的新篇章!1、洞察眼MIT系统采用先进的加密算法...

    2024-10-21 10:03:14
  • 2024办公必备!2024年必看的8款文件加密神器,超好用

    随着数字化办公的普及,文件加密已成为保护企业敏感信息和个人隐私的重要手段。2024年,我们为您精选了8款超好用的文件加密神器,它们不仅功能强大,而且操作简便,是办公人士的必备之选。无论是个人用户还是企业团队,都能在这些软件中找到适合自己的加密解决方案,让您的数据安全得到全方位的保护。1、洞察眼MIT系统系统采用先进的加...

    2024-10-21 08:58:14
  • 怎么给文件加密?简单加密法,五种文档加密保护伞

    在信息爆炸的时代,文件加密成为了保护隐私和数据安全的重要手段。无论是个人私密文件,还是企业核心资料,都需要得到有效的加密保护。本文将为您介绍五种简单实用的文档加密方法,这些方法操作简便,却能为您的文档筑起坚实的保护伞,让您在数字世界中畅游无忧,轻松守护每一份重要资料的安全。方法一:使用系统内置加密功能Windows系统...

    2024-10-21 08:53:34
  • 2024年超好用的企业防泄密软件分享|超实用企业防泄密软件TOP8

    随着数字化时代的到来,企业数据安全面临前所未有的挑战。2024年,我们精心挑选了超实用企业防泄密软件TOP8,旨在为企业提供全方位、高效的数据保护解决方案。这些软件不仅功能强大,而且操作简便,能够有效防止敏感数据泄露,保障企业信息安全。让我们一同探索这些防泄密神器,共同构建企业数据安全的坚固防线。1、洞察眼MIT系统系...

    2024-10-21 08:44:21
  • 如何远程控制员工的电脑?四款神器助你轻松实现!

    在快节奏的工作环境中,远程控制员工电脑已成为提升团队协作效率、确保信息安全的重要手段。然而,面对琳琅满目的远程控制软件,如何找到既高效又安全的解决方案?本文将为您推荐四款备受好评的远程控制神器,它们不仅功能强大,而且操作简便,助您轻松实现远程管理,让团队工作更加协同高效。1、洞察眼MIT系统远程控制功能:借助该系统,管...

    2024-10-19 14:57:35
  • 如何防止文档外发泄密?文档防泄密秘籍:六款热门加密软件推荐

    在数字化时代,文档的安全外发成为企业保护核心资产的重要一环。为了防止敏感信息被泄露,选择一款合适的文档加密软件至关重要。本文精心挑选了六款热门的文档加密软件,它们各具特色,旨在为您的文档安全保驾护航。无论您是大型企业还是个人用户,都能在这份秘籍中找到适合自己的加密工具,确保文档在传输和存储过程中的安全性。一、洞察眼MI...

    2024-10-19 14:22:10
  • 办公文件怎么加密?办公文件加密秘籍:8款软件大揭秘

    在数字化办公日益普及的今天,办公文件的安全保密显得尤为重要。如何确保敏感信息不被泄露?加密成为了不可或缺的手段。本文将为您揭秘8款高效实用的办公文件加密软件,它们各具特色,能够满足不同场景下的加密需求。无论是个人用户还是企业团队,都能从中找到适合自己的加密工具,为数据安全保驾护航。接下来,让我们一起探索这些加密秘籍吧!...

    2024-10-19 13:51:22
  • 屏幕监控软件有哪些?精选8款软件,实时监控你的电脑屏幕!

    在数字化办公日益普及的今天,屏幕监控软件已成为企业确保信息安全、提升管理效率的重要工具。它们能够实时监控电脑屏幕,有效防止数据泄露,规范员工行为。以下八款屏幕监控软件,凭借其强大的功能和广泛的应用场景,成为了市场上的佼佼者。1、洞察眼MIT系统系统能够实时监控局域网内计算机的桌面画面和操作行为。这意味着管理员可以实时查...

    2024-10-19 10:05:10

大家都在搜的词:

微信扫一扫联系售前工程师