大家好,我们现在来讲解关于加密方面的知识,说到加密我认为不得不提MD5,因为这是一种特殊的加密方式,它到底特殊在哪,现在我们就开始学习它

全称:message-digest algorithm 5

翻译过来就是:信息 摘要 算法 5

加密和摘要,是不一样的

加密后的消息是完整的;具有解密算法,得到原始数据;

摘要得到的消息是不完整的;通过摘要的数据,不能得到原始数据;

所以,当看到很多人说,md5,加密,解密的时候,呵呵一笑就好了。

MD5长度

有人说md5,128位,32位,16位,到底md5多长?

md5的长度,默认为128bit,也就是128个0和1的二进制串。

这样表达是很不友好的。

所以将二进制转成了16进制,每4个bit表示一个16进制,

所以128/4 = 32 换成16进制表示后,为32位了。

为什么网上还有md5是16位的呢?

网上有很多帖子,md5 32位 16位 加密 区别。

仔细观察admin生成的32位和16位的md5值……

查询结果:

md5(admin,32) = 21232f297a57a5a743894a0e4a801fc3

md5(admin,16) = 7a57a5a743894a0e

看出来了吧!

其实16位的长度,是从32位md5值来的。是将32位md5去掉前八位,去掉后八位得到的。

MD5的作用

①一致性检验,最上面那个例子

②数字签名,还是最上面那个例子。只是把md5看出了一个指纹,按了个手印说明独一无二了。

③安全访问认证,这个就是平时系统设计的问题了。

在用户注册时,会将密码进行md5加密,存到数据库中。这样可以防止那些可以看到数据库数据的人,恶意操作了。

md5是唯一的吗?

md5作为数据库中的主键可行吗?这就涉及到一个问题,md5值是唯一的吗?答案是,不唯一。

也就是一个原始数据,只对应一个md5值;

但是一个md5值,可能对应多个原始数据。

md5不能破解吗?

md5是不可逆的,也就是没有对应的算法,从生产的md5值逆向得到原始数据。

但是如果使用暴力破解,那就另说了。

Java语言中生成MD5的值

特点

  1. public class MD5Test {

  2. //main测试类

  3. public static void main(String[] args) {

  4. String result = getMD5("aaa");

  5. System.err.println(result);

  6. }

  7. /**

  8. * 生成md5

  9. * @param message

  10. * @return

  11. */

  12. public static String getMD5(String message) {

  13. String md5str = "";

  14. try {

  15. //1 创建一个提供信息摘要算法的对象,初始化为md5算法对象

  16. MessageDigest md = MessageDigest.getInstance("MD5");

  17. //2 将消息变成byte数组

  18. byte[] input = message.getBytes();

  19. //3 计算后获得字节数组,这就是那128位了

  20. byte[] buff = md.digest(input);

  21. //4 把数组每一字节(一个字节占八位)换成16进制连成md5字符串

  22. md5str = bytesToHex(buff);

  23. } catch (Exception e) {

  24. e.printStackTrace();

  25. }

  26. return md5str;

  27. }

  28. /**

  29. * 二进制转十六进制

  30. * @param bytes

  31. * @return

  32. */

  33. public static String bytesToHex(byte[] bytes) {

  34. StringBuffer md5str = new StringBuffer();

  35. //把数组每一字节换成16进制连成md5字符串

  36. int digital;

  37. for (int i = 0; i < bytes.length; i++) {

  38. digital = bytes[i];

  39. if(digital < 0) {

  40. digital += 256;

  41. }

  42. if(digital < 16){

  43. md5str.append("0");

  44. }

  45. md5str.append(Integer.toHexString(digital));

  46. }

  47. return md5str.toString().toUpperCase();

  48. }

  49. }

tagged with JAVA, md5, MD5长度, 加密, 唯一, 摘要, 生成, 破解

1.长度固定:

  • 不管多长的字符串,加密后长度都是一样长
    作用:
    方便平时信息的统计和管理

  • 2.易计算:

    字符串和文件加密的过程是容易的.
    作用: 开发者很容易理解和做出加密工具

  • 3.细微性

    一个文件,不管多大,小到几k,大到几G,你只要改变里面某个字符,那么都会导致MD5值改变.
    作用:
    很多软件和应用在网站提供下载资源,其中包含了对文件的MD5码,用户下载后只需要用工具测一下下载好的文件,通过对比就知道该文件是否有过更改变动.

  • 4.不可逆性

    你明明知道密文和加密方式,你却无法反向计算出原密码.
    作用:基于这个特点,很多安全的加密方式都是用到.大大提高了数据的安全性

加密字符串

逻辑思维:

  • 1.获取信息摘要对象:md5

    通过信息摘要单例的构造函数获取:

    ​MessageDigest md5 = MessageDigest.getInstance("MD5");
    
  • 2.信息摘要对象是对字节数组进行摘要的,所以先获取字符串的字节数组.

    ​byte[] bytes = str.getBytes();​
  • 3.信息摘要对象对字节数组进行摘要,得到摘要字节数组:

    ​byte[] digest = md5.digest(bytes);​
  • 4.把摘要数组中的每一个字节转换成16进制,并拼在一起就得到了MD5值.
    (PS,有些转换过来得到的是前面有6个f的情况,如:ffffff82,这是因为前面有6组4个1,所以提前把这6组1111先变成0就好了,然后再转16进制就没有f了)
    (其实也可以在后面续把f去掉)

MD5 加密算法介绍相关推荐

  1. DES、AES、RSA等常用加密算法介绍与比较

    文本先简单介绍常用的加密算法,后面将逐步推送每个加密算法的加密原理与应用及java实现方式. 加密算法分对称加密和非对称算法,其中对称加密算法的加密与解密密钥相同,非对称加密算法的加密密钥与解密密钥不 ...

  2. 简要分析用MD5加密算法加密信息(如有疑问,敬请留言)

    一.引言 最近看了媒体的一篇关于"网络上公开叫卖个人隐私信息"报导,不法分子通过非法手段获得的个人隐私信息,其详细.准确程度简直令人瞠口结舌.在互联网飞速发展的现在,我们不难想到, ...

  3. MD5加密算法及其在Java中的使用

    MD5算法简介 MD5是不可逆的单向加密算法,因为哈希算法是不可逆的,简单来说,就像我们可以获知5%2=1,3%2=1,7%2=1,但是,当我们仅仅拿到结果1的时候并不知道这是哪个数对2取余得到的结果 ...

  4. java md5加密长度_java中使用MD5加密算法进行加密

    java中使用MD5加密算法进行加密以下文字资料是由(历史新知网www.lishixinzhi.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧! 在各种应用系统的开发中 经常需要存储 ...

  5. 工具类—MD5简单介绍以及MD5工具类

    2.MD5简单介绍: 1)MD5是什么鬼?: 答:Message Digest Algorithm MD5(中文名为消息摘要算法第五版)为计算机安全领域广泛 使用的一种散列函数,用以提供消息的完整性保 ...

  6. MD5加密介绍、工具类的使用

    目标 了解什么是md5,它有哪些特点 使用md5的工具类对字符串进行加密 提高md5的加密程度 应用场景 ​ 在企业中,登录账户表,里面的密码是加密的,为了防止数据管理员或IT部内部人员数据泄密.注册 ...

  7. md5碰撞介绍及工具,并对百度网盘进行碰撞

    md5碰撞介绍及工具,并对百度网盘进行碰撞 前言 什么是MD5 什么是MD5碰撞 md5碰撞 常见的碰撞法 差分攻击 构造前缀碰撞法 快速 MD5 碰撞生成器使用方法 百度网盘md5碰撞攻击 总结 参 ...

  8. java自带的md5加密_JDK自带MD5加密算法

    [     在各种应用系统的开发中,经常需要存储用户信息,很多地方都要存储用户密码,而将用户密码直接存储在服务器上显然是不安全的,本文简要介绍工作中常用的 MD5加密算 其实jdk就自带了md5加密算 ...

  9. md5加密算法原理及其GO语言实现

    md5加密算法原理及其GO语言实现 MD5讯息摘要演算法(英语:MD5 Message-Digest Algorithm),一种被广泛使用的密码杂凑函数,可以产生出一个128位元(16位元组)的散列值 ...

最新文章

  1. Rider 2018.3.4 发布,跨平台 .NET IDE
  2. MA5680T跨板聚合
  3. jquery实现截取pc图片_jquery 上传图片自由截取
  4. linux下解除端口占用
  5. SQL中常见的6个报错
  6. EasyWeChat微信开放平台第三方平台接入
  7. mysql linux 安装_mysql-5.7.28 在Linux下的安装教程图解
  8. JS-面向对象-改变This的指向---使用call方法改变this的指向 / 使用apply方法改变this的指向 / 使用bind方法改变this的指向
  9. OpenShift 4 - 部署一个基于 Serverless 的 Banking 应用
  10. Axure高保真移动端电商app通用模板、axure高保真移动端教育app通用模板、旅游app通用模板、电商app、教育app、旅游app 、直播、在线教育、旅游、Axure原型、rp原型
  11. 从不同解码策略看机器如何生成文本
  12. [leetcode]1185. 一周中的第几天
  13. python day10
  14. 基于朴素贝叶斯的鸢尾花数据集分类
  15. cocos2dx基础篇(10)——编辑框之一CCTextFieldTTF
  16. vscode调试cpp环境,手动安装vsix
  17. 下载谷歌瓦片地图并拼接为高清大图
  18. 《麦肯锡工作法》读书分享
  19. 万字拆解江小白:新品牌做白酒,敢问路在何方?
  20. 【实用】齐齐哈尔市公交车线路站点汇总

热门文章

  1. C语言——实例010 打印楼梯,同时在楼梯上方打印两个笑脸。
  2. 诊所预约管理系统-电子病例功能
  3. 关于R语言中的sum和length计算长度
  4. JAVA 获取项目路径
  5. 关于生成\读取 一维码二维码的方法
  6. win10 子系统 ubuntu GPU驱动,CUDA, CUDNN安装与 win10 GPU 机器学习性能对比, numa_node 问题
  7. Word字号和像素的对应关系
  8. 短视频配音软件哪些好用?大家都在用的短视频配音软件
  9. 安卓APP隐私合规问题处理记录
  10. GD32 flash写保护解除