同一字符串,MD5加密后出现不同的结果

同一字符串,MD5加密后出现不同的结果


背景

公司数据采用MD5加密和ssl双向认证,最近把项目部署到服务器进行测试,结果MD5验证总是通不过,服务器在请求过来的加密32位串和本地加密32位串作对比时,总是返回false,那么问题来了,加密之前的明文是相同的,为何同样的加密方法却得到了不同的结果?

问题分析

首先考虑到的是操作系统的不同,win下运行正常的代码为何到linux下就不行了,但是MD5加密并不会受到不同系统的影响,这个原因被否决了。
最终问了下技术经理,问题原因才定位出来,问题就出在编码上,我们的项目的默认编码是GBK的编码,win下的默认编码也是GBK的编码,而linux一般情况下默认编码是UTF-8的编码,查看项目中确实有字段包含中文且没有对编码作出处理,传输字段理的不够清楚。

解决方案

对传输的数据指定编码即可解决问题:

String "处理后字符串" = URLEncoder.encode("处理前字符串", "utf-8");

思考

  1. 一定要找准自己的位置,切勿自以为是,简单的会用一些技术,通了,搞定了,就意味自己掌握了,这是一个非常大的误区。
  2. 要对技术的真正实现原理清楚,只有了解真正的原理,代码的效率才会高,遇到问题就不会没头没脑,浪费宝贵的时间。
  3. 这种简单的解决方案可能存在不足,以后需要多了解编码方面的知识。

©版权归Peiel所有,转载请注明出处。

  • 9
    点赞
  • 16
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
### 回答1: 是的,如果两个字符串相同,那么它们经过 MD5 加密后得到的结果也是一致的。MD5 是一种不可逆的加密算法,它将任意长度的字符串转换为固定长度的散列值。因此,两个相同的字符串经过 MD5 加密后得到的散列值也是一致的。 ### 回答2: 是的,两个相同的字符串经过MD5加密后的结果是一致的。MD5(Message Digest Algorithm 5)是一种常用的哈希函数算法,它能将任意长度的字符串映射成固定长度的唯一字符串。无论输入的字符串有多长,其计算出的MD5值都是固定的128位二进制数字。因为MD5算法通过对输入字符串的每个字符进行计算,并结合特定的位运算和逻辑运算来生成MD5值,而输入字符串相同,计算过程和运算规则也相同,所以最终得到的MD5值一定是相同的。因此,不论使用什么编程语言或工具,在对相同的字符串进行MD5加密时,无论何时何地执行,其结果都是一致的。这也是MD5广泛用于数据校验和密码存储的原因之一,可以通过比对MD5值来验证数据的完整性或者验证用户输入的密码是否正确。然而,需要注意的是,MD5被认为是不安全的哈希函数,因为其碰撞攻击等安全漏洞已被发现,目前更加推荐使用SHA-256等更安全的哈希算法。 ### 回答3: 两个相同的字符串经过MD5加密后的结果是一致的。MD5(Message Digest Algorithm 5)是一种常用的消息摘要算法,它将任意长度的输入数据压缩为128位(16字节)的散列值。无论输入数据多长,MD5生成的散列值都是固定长度的。因此,对于相同的输入,无论是多少次加密,其MD5散列值都是一样的。 举个例子,对于字符串"hello",经过MD5加密后的结果是5d41402abc4b2a76b9719d911017c592。无论是第一次还是多次加密,结果都是一样的。当我们再次加密"hello"这个字符串时,MD5算法会将其转换成相同的散列值,即5d41402abc4b2a76b9719d911017c592。 因此,对于两个相同的字符串,无论进行多少次MD5加密,其结果都是一致的。这也是MD5算法被广泛应用于数据完整性校验、密码存储等领域的原因之一。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值