当前位置 博文首页 > 程序员吴师兄的博客:阿里三面,MD5 到底是不是加密算法?

    程序员吴师兄的博客:阿里三面,MD5 到底是不是加密算法?

    作者:[db:作者] 时间:2021-06-13 09:36

    在回答这个问题之前,我们先分别来了解一下两个知识点:

    • 什么是 MD5 算法?

    • 什么是加密算法?

    一、MD5算法

    MD5 即 Message-Digest Algorithm 5(信息-摘要算法5),用于确保信息传输完整一致。是计算机广泛使用的杂凑算法之一,主流编程语言普遍已有 MD5 实现。

    将数据(如汉字)运算为另一固定长度值,是杂凑算法的基础原理,MD5 的前身有 MD2 、MD3 和 MD4 。

    MD5 是输入不定长度信息,输出固定长度 128-bits 的算法。经过程序流程,生成四个32位数据,最后联合起来成为一个 128-bits 散列。

    基本方式为,求余、取余、调整长度、与链接变量进行循环运算,得出结果。

    MD5 计算广泛应用于错误检查。在一些 BitTorrent 下载中,软件通过计算 MD5 来检验下载到的碎片的完整性。

    二、加密算法

    百度百科:加密,是以某种特殊的算法改变原有的信息数据,使得未授权的用户即使获得了已加密的信息,但因不知解密的方法,仍然无法了解信息的内容。

    维基百科:在密码学中,加密(英语:Encryption)是将明文信息改变为难以读取的密文内容,使之不可读的过程。只有拥有解密方法的对象,经由解密过程,才能将密文还原为正常可读的内容。

    三、对比

    也就是说,MD5 算法和加密算法都可以将信息转换为另外一种内容。

    但是,MD5 算法对比 加密算法 缺少了解密过程。

    事实上,使用 加密算法 加密后的消息是完整的,并且基于解密算法后,可以恢复原始数据。

    而 MD5 算法 得到的消息是不完整的,并且通过摘要的数据也无法得到原始数据。

    所以,MD5 算法不是加密算法!

    学弟学妹们,你们学会了么?

    作者简介

    作者:大家好,我是程序员吴师兄,在 GitHub 上开源了一个项目 LeetCodeAnimation,目前有 60k star,通过动画的形式讲解算法,已经帮助成千上万的程序员入门算法了,欢迎关注公众号「五分钟学算法」,和我们一起学习算法。
    转载说明:未获得授权,禁止转载