MD5加密

Posted 杀手不太冷!

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了MD5加密相关的知识,希望对你有一定的参考价值。

MD5加密

基本概念信息

**首先什么叫做加密?**加密,是以某种特殊的算法改变原有的信息数据,使得未授权的用户即使获得了已加密的信息,但因不知道解密的方法,仍然无法了解信息的内容。

**对称加密?**对称加密的加密和解密用的是同一个密钥。

**非对称加密?**非对称加密的加密和解密用的是不同的密钥。凯琳现在想把一段数据传递给鲍勃,但是如果凯琳在网上使用明文传输,她担心她的这段信息会被别人获取到,所以怎么办呢?凯琳可以先得到鲍勃的公钥,然后使用鲍勃的公钥对明文进行一次加密,加密成密文,最后鲍勃获取到密文的时候,再使用自己的私钥解密,这样就可以了。

摘要算法?摘要算法也称为哈希算法,散列算法,可以将任意长度的数据转换成一个定长的,不可逆的数字。什么叫做定长呢?就是你的数据不管是多长,最后转化为摘要之后都是定长;什么叫做不可逆的数字?摘要算法不像对称算法和非对称算法,因为他们加密之后都是可以被解密的,但是摘要算法加密之后是不能够通过解密获取原文的,它的加密是不可逆的。

只要原文不同,计算的结果必然不同(几乎不用考虑重复的情况)。摘要算法用于对比信息源是否一致,因为只要数据源发生变化,得到的摘要信息必然不同,通常用于签名校验。

消息摘要算法的特点:

  • 无论输入的消息有多长,计算出来的消息摘要的长度总是固定的。
  • 消息摘要不是真正的随机,因为用相同的消息求两次摘要,其结果必然相同。
  • 消息摘要函数是无陷门的单向函数,即只能进行正向的信息摘要,而无法从摘要中恢复出任何的消息,甚至根本就找不到与原信息相关的信息。

常见的摘要算法有:MD5,SHA-1,MAC,CRC等。

广泛应用于校验数据的完整性和敏感信息的传输和保存。

MD5算法:MD5信息摘要算法,一种广泛使用的密码散列函数,可以产生出一个128位(16字节)的散列值,用于确保信息传输完整一致。2004年,证实MD5算法无法防止碰撞(collision),因此不适用于安全性认证,如SSL公开密钥认证或是数字签名等用途。

**什么叫做碰撞?**我们使用MD5加密的密文是无法被还原回来的,但是如果我们有一个保存常见密码和MD5密文映射关系的加密库,那么我们就可以通过对照密文,进而知道对应的原文是什么。

基本应用

**md5-min.js和md5.js的区别?**md5.js是格式良好的js,是给开发人员开的;md5-min.js是压缩版的js,是给浏览器看的。

md5前端加密如下:

<!DOCTYPE html>
<html lang="en">

    <head>
        <meta charset="UTF-8">
        <title>Document</title>
        <script type="text/javascript" src="./md5.js"></script>
        <script type="text/javascript">
        	/**
        	 * md5加密之后   admin   =>   21232f297a57a5a743894a0e4a801fc3
        	 * */
        	console.log("md5    =>     "+hex_md5("admin"));
        	/**
        	 * 加盐(MD5没有办法通过算法进行解密,但是可以被暴力破解【彩虹表】,不够安全,彩虹表其实就是一个明文与密文
        	 * 映射的数据库表)
        	 * 盐就是一个特定的字符串(自己指定)的,用来和加密后的内容进行混合,混合后的内容再次进行md5加密,数据就更安全
        	 * 比如:
        	 * 		admin			salt => 0x3d1eaaa
        	 * 		让文本和salt进行混合(随意)
        	 * 		admin0x3d1eaaa
        	 * 		然后对混合后的文本进行md5加密操作,这样就算我们的密文被破解了出来,但是它也不知道我们的明文是什么
        	 * */

        </script>
    </head>
    <body class="index">
        我是body
    </body>

</html>

MD5算法和RSA算法加密的异同

首先MD5加密可以确保,只要原文内容不同,那么最后加密的结果一定是不同的。并且每个明文,它加密后的密文都是固定的,都是不会发生变化的。但是MD5加密无法防止别人的彩虹表碰撞,就是它可能会有一个常见明文和MD5密文的映射表,所以如果我们的密码设置的是弱密码,可能会被人破解。并且MD5加密是单向的,我们只能把明文加密成MD5密文,但是却不能方向把MD5密文解析成明文。
RSA加密每次加密的结果都是不一样的,并且RSA加密是双向的,即我可以先加密获取密文,然后再解密密文获取明文。

以上是关于MD5加密的主要内容,如果未能解决你的问题,请参考以下文章

关于sha1加密与md5加密

Java实现MD5(32/16位)大小写加密

使用python之MD5进行加密

MD5加密C#和js代码加密结果不同

php网站密码md5加密串比较方式

callback和spring的MD5加密