芯片安全攻防科普系列:秘密的语言——密码学入门
日常生活中的难题:课堂上的秘密纸条
想象一下学生时代,你和同桌想在课堂上传纸条,但又不想被老师或者其他同学看懂内容。如果直接写“下课一起去打球”,一旦纸条被截获,你们的秘密计划就泡汤了。
一个简单的解决方案是,你们提前约定好一种“暗语”。比如,把每个字母都替换成它在字母表中的下一个字母(A 变成 B,B 变成 C……)。这样,纸条上写的就成了“下课一起去打球”的“密文”版本——“下课一起去打球”。这张纸条即使被别人拿到,看到的也是一串无法理解的文字。只有知道这个“字母+1”规则的你和同桌,才能把它翻译回原来的意思。
这个简单的“暗语”游戏,其实就是密码学的基本思想。原始信息是“明文”,约定好的规则是“密钥”,翻译后的乱码是“密文”。在数字世界里,我们用极其复杂的数学算法来扮演这个“暗语”的角色,保护着我们在网络中传递的每一个秘密。
解锁保险箱的难题:为何我们需要密码
在上一部分我们留下了悬念:如果攻击者能窃听到智能卡和读卡器之间的通信,如何保护传输的信息不被泄露?这就像两个特工在敌方监听下传递机密情报,他们需要一种只有彼此才能听懂的“暗语”。在数字世界,这种暗语就是密码学(Cryptography)。
密码学的核心任务,是将原始的、可读的信息(称为明文,Plaintext)通过一种数学算法转换成看似毫无意义的乱码(称为密文,Ciphertext)。而解开这个乱码、将其还原为明文的唯一方法,就是掌握一把特殊的钥匙(称为密钥,Key)。一个优秀的加密算法,必须确保即使攻击者获取了全部密文,在没有密钥的情况下,也无法推断出明文的任何内容。
一把钥匙开一把锁:对称加密 (AES)
想象一个保险箱,你用一把钥匙锁上它,然后把这把钥匙交给你的朋友,你的朋友必须用这把完全相同的钥匙才能打开保险箱。这就是对称加密的核心思想:加密和解密使用同一把密钥。
这种方法的优点非常突出:速度快、计算效率高。因此,它非常适合对大量数据进行加密,比如加密整个文件、视频流或者持续的网络通信。目前,全球公认的对称加密标准是高级加密标准(Advanced Encryption Standard, AES)。从政府机密文件到银行交易数据,AES 无处不在,它提供了不同强度的密钥长度,如 128 位、192 位和 256 位,密钥越长,破解的难度就越大。当然,除了国际标准,许多国家和地区也有自己的加密标准,例如在中国,相关应用就需要使用国密算法安全芯片来实现合规的加密保护。
然而,对称加密有一个致命的“阿喀琉斯之踵”——密钥分发难题。如果你和远方的朋友想用同一个保险箱和钥匙通信,你如何才能安全地把这第一把钥匙送到他手上呢?如果通过普通邮寄,钥匙可能会被中途截获,那么之后所有用这个保险箱传递的信息都将不再安全。这个问题引出了另一种截然不同的加密哲学。
公开的信箱与私密的钥匙:非对称加密 (RSA & ECC)
为了解决密钥分发难题,密码学家们设计出了非对称加密。让我们换一个比喻:一个特制的安全邮箱。这个邮箱有一个投信口,任何人都可以把信件(加密后的信息)投进去,这个投信口就是公钥(Public Key),可以分发给全世界。但是,邮箱只有一个坚固的门,并且只有一把钥匙能打开它,这把钥匙由邮箱的主人自己保管,绝不外泄,这就是私钥(Private Key)。
非对称加密的精髓在于拥有一对在数学上相关联的密钥:公钥和私钥。用公钥加密的信息,只有对应的私钥才能解密;反之亦然。最关键的一点是,你无法通过公钥推导出私钥。这样一来,密钥分发问题迎刃而解:你只需把你的公钥(投信口)告诉所有人,任何人想给你发送机密信息时,就用你的公钥加密,然后只有拥有私钥的你才能阅读。
非对称加密领域的两大“功臣”是 RSA 和 ECC。RSA(以其三位发明者 Rivest-Shamir-Adleman 命名)是经典且应用最广泛的非对称算法。而**椭圆曲线密码学(Elliptic Curve Cryptography, ECC)**则是更现代、更高效的替代方案。ECC 的巧妙之处在于,它可以用更短的密钥长度达到与 RSA 同等级别的安全性,这使得它在计算能力和功耗受限的设备上(如智能手机和芯片卡)表现得尤为出色。
强强联合:现实世界如何运用混合加密
既然对称加密快,而非对称加密解决了密钥分发问题,那么为什么不把它们结合起来呢?这正是现代安全通信系统的基石——混合加密。像立安微电子这样的公司,其提供的安全方案也常常是基于这种混合加密的理念来平衡安全与效率。
这个过程好比你要和朋友交换大量沉重的宝箱(大批量数据),用那种只有一个锁和一把钥匙的普通挂锁(对称加密)最方便快捷。但是,你首先需要把挂锁的钥匙安全地送给朋友。于是,你动用了那个虽然慢但绝对安全的特制邮箱(非对称加密),把挂锁钥匙放进一封信里,用朋友的公钥加密后投递。朋友收到后用自己的私钥打开信,拿到了挂锁钥匙。从此以后,你们俩就可以用这把共享的钥匙,快速地交换无数个宝箱了。
这个过程完美地体现在我们每天都在使用的 TLS/SSL 协议(也就是网址栏里那个“https”的由来)中:
1. 你的浏览器(如 Chrome)向网站服务器请求其公钥。
2. 浏览器在本地生成一个临时的、一次性的对称密钥(比如一个 AES 密钥),然后用网站的公钥将其加密后发送给服务器。
3. 网站服务器用自己的私钥解密这条信息,从而安全地获取了这个对称密钥。
4. 至此,浏览器和服务器拥有了同一个秘密的对称密钥。在接下来的整个会话中,双方都使用这个密钥和高效的 AES 算法来加密所有实际传输的数据(网页内容、你的登录密码等)。
这种设计体现了安全工程的智慧:它并非简单地在不同算法中“选一个最好的”,而是构建了一个巧妙的系统,用不同工具的优势去弥补彼此的劣势。非对称加密就像一位经验丰富的外交官,负责建立信任和安全地交换“国书”(密钥);而对称加密则像一位高效的运输队长,负责在信任建立后快速、安全地运送大量“物资”(数据)。这种对速度和安全性的精妙权衡,是现代密码学体系的核心思想。
表 2:对称加密 vs. 非对称加密
| 特性 | 对称加密 (如 AES) | 非对称加密 (如 RSA, ECC) |
| 密钥数量 | 1个 | 2个 (公钥和私钥) |
| 密钥关系 | 加密和解密使用完全相同的密钥 | 公钥和私钥在数学上配对,但不同 |
| 速度 | 非常快 | 相对较慢 |
| 主要用途 | 大批量数据加密(数据传输、文件加密) | 密钥交换、数字签名 |
| 核心挑战 | 如何安全地分发共享密钥 | 计算开销大,对性能要求高 |
| 形象比喻 | 一把钥匙开一把锁的挂锁 | 公开的投信口和私密的开箱钥匙 |
DAMO开发者矩阵,由阿里巴巴达摩院和中国互联网协会联合发起,致力于探讨最前沿的技术趋势与应用成果,搭建高质量的交流与分享平台,推动技术创新与产业应用链接,围绕“人工智能与新型计算”构建开放共享的开发者生态。
更多推荐


所有评论(0)