实用密码学

开篇词 | 人人都要会点密码学

范学雷

前Oracle首席软件工程师,Java SE安全组成员,OpenJDK评审成员

你好,我是范学雷。

2020年,庚子年。如果你问我,2020年有什么愿望,我想说,这一年,咱们能不能重启?如果一切真的可以重启,哪些事情是我们可以做得更好的?哪些问题是我们依然无法避免的?

如果可以重来,我想,Zoom 最想做的,一定是聘用密码学领域的专家,提高研发人员的密码学见识,让研发人员都学会和用好密码学。

Zoom怎么了?

Zoom怎么了?为什么Zoom要和密码学较劲?

熟悉在线会议系统的都应该知道,Zoom 是这个领域的市场领先产品。2020年初,随着COVID-19(新冠肺炎)在全球的蔓延,高质量的在线会议变成了一个居家办公、远程工作的必需品。

这时候的Zoom,也做好了所有的准备,它很好地满足了人们远程工作的急切需求。直到2020年3月底,Zoom都是主流市场的主要选择之一。

然而,到3月底,事情急转直下。2020年3月31日,研究者公开了Zoom的重大安全漏洞,认为Zoom并不适用于办公会议。最严重的问题,是和密码算法密码管理相关的问题

比如说,Zoom使用了ECB加密模式,而这种加密模式并不是一种安全的加密模式。而且,这件事也不是秘密,ECB加密模式的安全问题至少披露了二三十年了。

随后,有不少知名的公司、教育机构以及政府组织,出于信息安全的考虑,禁止使用Zoom,转而寻找替代产品。本该大展身手、攻城略地的时候,Zoom被闷头打了一棒,把大量的机会拱手让给了竞争对手。而这种市场机会,我认为前五十年未见,后五十年难寻。

不过,Zoom马上聘用了安全领域的专家,全力以赴地解决掉了这些问题。幸运的是,对Zoom来说,这些问题发现得并不算晚,应对得也不算拖拉。不幸的是,由于算法选择失当这样的“小问题”,Zoom给了竞争者充分的空间,自身的品牌和信誉也受到了很大的伤害。

Zoom是个特例吗?

安全漏洞的角度来看,单个问题本身并不可怕。重要的是我们该怎么快速反应,该怎么杜绝后患。杜绝后患的思路之一,就是要求同样的安全问题,一定不要重复上演。

我相信,Zoom可以做到这一点。但是,其他的公司呢?其他的产品呢?很遗憾,我不相信Zoom会是最后一个用错了ECB加密模式的产品或者公司。现在和未来,依然会有人用错ECB加密模式,以及其他的密码算法。

今天,用错密码算法的产品和公司,能够快速反应并及时修复它们的安全问题吗?明天的产品和服务,能够做到在合适的场景下,使用合适的密码算法吗?对于答案,我依然有些悲观。

我之所以悲观,是因为大部分产品的研发人员,甚至都不知道ECB加密模式有什么问题,当然在使用它的时候也就很无畏。

如今,能够做到在不同的场景,使用不同的密码算法的研发人员,数量还很少;懂得密码学的安全领域的专家,数量更少;能够跟得上密码学发展进程的研发人员,数量更是少得可怜可叹。

为什么要学密码学?

为什么会这样?其实,这里面既有历史原因,也有学科原因。

十多年以前,操作系统和通信协议这样的基础设施,通过内嵌的安全机制,就可以满足大部分的点对点的信息安全需求了。所以,那时候的信息安全直接需求并没有那么大。

再加上现代密码学门槛高、出道晚,它的这种特殊性让其一直都是少数人的游戏。即使是数字化时代,隐私保护和信息安全已经成为重要议题的时候,密码学也没有成为每个程序员的必修课。

但是,十年以前,这或许不是问题。可是,从今以后,这会是一个越来越严重的技术债。

因为,现代信息安全的需求,越来越多地跳出了基础设施的范畴,进入了应用程序层面。

操作系统、通信协议这样的基础设施,早就已经满足不了应用的多样化需求了。比如,像Zoom这样的在线会议产品的安全需求,底层的基础设施提供的安全保障能力,是远远不够的。

不过,好在机遇与挑战总是并存的。近年来我参加的每一次密码学会议,都会有人提到密码学专业人才的短缺。的确是这样的,市场的需求和供给之间有一个巨大缺口。

总的来说,现在密码学的市场情况主要有以下两个特点:

  • 密码学领域难以招聘,即使平均报酬已经高出了一大截;不过这也使得与密码学相关的工作超级稳定,很少会看到一个信息安全工程师有35岁的忧愁,抑或45岁的哀伤。
  • 密码学应用很尴尬,由于研发团队缺乏专业的密码学素养,算法场景错配或使用有安全漏洞的算法和协议的问题层出不穷。遗憾的是,这个缺口还没有停止扩张的迹象。

密码学虽是一个小门类,但是涉及内容庞杂。从踏进门到能够使用密码学技术去设计一个像样的、安全的系统,需要短则两三年、长则七八年的积累。所以,无论是领取报酬的工程师或者是支付薪酬的公司,有耐心的实在是少数。

当然,好的耐心是有回报的。不同于其他的软件工程师,密码学是一个需要深度积累的领域,年头越长,见识越多,越了解其中的坑坑洼洼,生产效率和产品质量也越高。可以这么说,有经验的信息安全工程师,是每一个公司的关键人力资源。

45岁,好日子才刚刚开始。

如何学习密码学?

既然密码学这么难,如果我们想学习密码学的知识,该从哪里开始呢?有没有办法降低门槛?

学习的途径,不外乎两个:读书和培训。

密码学最好的书籍,当属Bruce Schneier的《应用密码学:协议、算法与C源程序》。这应该没有太多争议。很多同学的密码学入门,就是从这本书开始的。二十多年前,我也是从这本书开始的。即使是现在,它也是我能在市场上找到的、最好的密码学入门书籍。

不过,和其他密码学书籍一样,这本书虽然叫做应用密码学,对于普通的软件工程师,它依然太难了。除此之外,这本书的内容,是1996年之前的密码学世界,和现在的密码学相差有点远。

其中提到的算法,很少还能够继续使用了;书中的源代码,无论是理论上还是实践上,都有很多的安全漏洞,也已经不能用在现在的产品中了。所以,如果你发现,一个产品还在使用这本书的算法和源代码,它的安全性是值得你担心的。

这就需要我们重新审视和评价现在的密码算法:哪些还能用?哪些要淘汰?不同的场景,应该使用什么样的算法?使用算法的时候,有哪些常见的陷阱?作为软件开发者,我们应该掌握哪些密码技术?掌握到什么程度?这些问题,都是我们要重新梳理,重新认识的。

一般来说,非密码学专业领域的研发人员,是不需要了解密码算法的数学细节和实现细节的。那么,我们应该了解哪些密码学知识呢?我认为主要有以下三点:

  • 密码学可以解决什么样的问题?

也就是说,我们需要了解密码学的基本概念和体系,知道密码学能解决什么样的问题,不能解决什么样的问题。这就算是敲了敲密码学的大门了。

  • 面对具体的问题,我们应该使用什么样的密码技术?

也就是说,如果遇到具体的问题,我们应该选择什么样的算法,当心什么样的问题。这需要我们了解每一个算法的适用场景,以及它的局限性。这算是跨进大门,打怪晋级,修炼十八般武艺。

  • 面对真实的产品,应该怎样组合不同的密码技术?

一般来说,一个产品里需要组合多种密码技术,才能够实现信息安全。单独耐看的技术,搭配起来可能就是一团糟。这需要我们组合、搭配好不同的密码技术,甚至包括非密码的信息安全技术。也就是把密码技术用起来,解决真实的问题。

简单地说,就是要学会、用好密码学。

这个专栏教你什么?

我会带你厘清密码学及其算法背后的基本概念和基本逻辑。只有基本概念和基本逻辑弄清楚了,我们才会降低用错密码学技术的风险。这个专栏也是围绕基本概念和基本逻辑安排的。

不过,你不用担心基础知识枯燥难学。不同于一般的密码学课程和教材,我会把重点放在各种密码技术的适用场景和局限性上。因为,单纯地学习密码学的知识,其实没有特别大的用处,弄清楚基本概念和基本逻辑最好的办法,就是了解支持它们的实际问题和现实需求。

所以,这个专栏的每一篇文章,都是从问题开始的,也是以问题结束的。可以说,实际问题和现实需求是领着我们一步一步深入密码学内部的线索。

你也知道,用错密码学的后果很严重。所以,教你用好密码学,就是这个专栏的目标。我想通过这个专栏帮助你把握住基本概念、弄明白适用场景、躲得开常见错误

不过,要学好这个专栏,还需要你做好两件事。

第一件事情是关注问题。当你阅读的时候,如果遇到提出问题的文字,停下来思考一小会儿,看看自己有没有什么想法,或者更多的问题。专栏里,我们会提出很多问题,每一个问题,都会引出更多的内容,甚至更多的问题。

你只有认真地思考了每一个问题,才能掌握这个问题,才能对后续的解决方法有更深入的了解。在密码学的世界里,了解问题总是比掌握解决方法还要重要。

第二件事情是提出问题。除了专栏里提出的问题之外,你会不会发现新问题,有没有新思路?密码学算法最神奇的地方之一,就是外行看觉得好完美,内行看觉得好无奈。

因为,密码学的每一个基本概念,都有它的缺陷;每一个算法,都有要命的缺点。专栏里,我试着向你去提出最关键的问题。但是毫无疑问,我不能覆盖所有的问题。

但我相信专栏里提问题的角度能给你一些启发,帮助你从不同的角度,掂过来倒过去地琢磨每一个基本概念和算法,看看你有没有新问题,有没有新思路。你能够找到无奈的地方越多,你对问题的了解就越深入,学到的东西也就越多。

说实话,这个专栏有点硬,不是一个讲故事、听故事的专栏。我尽了自己最大的努力使它平实易懂,但是它依然是一个硬得硌人的专栏。这个硬度的主要来源,不是因为难懂,是因为我们要不断地思考各种各样的问题,而不是我塞给你一堆知识。

另外,本专栏会主讲密码学的基础知识和逻辑,对于密码学中较难的部分:非对称密码技术,我们课程暂时不会过多涉及。你可以先打好基础,再去拓展进阶的知识,这对于你来说,才是一条更好的学习路径。

我是谁?

最后介绍一下我自己吧。

我是范学雷,在密码学应用领域已经工作了二十多年了。目前,担任Oracle的首席软件工程师,是Java安全组的成员,OpenJDK安全评审成员,也是Java安全的主要推动者和贡献者之一。

我的日常工作包括关注信息安全威胁与技术进展,参与信息安全领域国际合作,制定与实现 Java 安全规范,提升 Java SE 生态安全水准,促进 Java 技术的普及与运用等。

我曾在极客时间做过第一季专栏《代码精进之路》,在那个专栏里,我总结了自己20多年的编程心得和代码评审经验。而这一次,我希望可以带你走一小段密码学的旅程。

如果你还没有密码学的基础,那我们就可以从这里开始;如果你已经学习了《应用密码学》,或者有密码学应用的经验,那我们可以一起去看看密码学最新的进展,以及最新的密码学算法。

欢迎在留言区留言,记录、讨论你的想法,或者写下你的期待,让我们一起努力!

好,我们开始吧!

教程推荐

JavaScript在线教程

Kotlin在线教程

Seaborn在线教程

Nginx在线教程

大数据学习指南在线教程

JavaScript 代码整洁指南在线教程

随机推荐

朗适RS100评测好不好用?真相揭秘实际情况!

狮王小狮王儿童氟防蛀牙膏 20g分享一下使用心得?亲身评测体验诉...

雀巢超启能恩奶粉3段760g*4罐好不好,入手推荐?良心评测点评!

蒙牛纯甄草莓果粒常温酸奶200g×10入手怎么样?最真实的使用感受...

蒙牛纯甄草莓果粒常温酸奶200g×10分析怎么样?老司机评测分享?

佳沃云南蓝莓14mm 12盒原箱生鲜使用舒适度如何?最真实的使用感...