(编程语言界的丐帮 C#).NET MD5 HASH 哈希 加密 与JAVA 互通
一。注意要点
1:输入字符串的的编码双方保持统一,如:UTF8;
2:HASH计算输出结果 byte[] 数组转String 时,编码要统一,如:转16进制小写字符串。当然也可以转Base64。
3:如果是16进制字符串,双方大小写要统一。
二。C#
先看一个常见代码:
public static String Md5Hash(String str)
{
MD5 md = MD5.Create();
byte[] bytes = Encoding.UTF8.GetBytes(str);
byte[] buffer2 = md.ComputeHash(bytes);
string rst = "";
//小写的 x2 是16进制小写。大写 X2 是转16进制大写。
for (int i = 0; i < buffer2.Length; i++)
{
rst = rst + buffer2[i].ToString("x2");
}
return rst;
}
解析:
“MD5 md = MD5.Create();” 获取一个C# MD5对象。
“byte[] bytes = Encoding.UTF8.GetBytes(str);”,将输入字符串用UTF8编码转为byte[] 数组,方便下一步给ComputeHash()方法计算。
“rst = rst + buffer2[i].ToString("x2");”,拿到HASH结果后,逐字节转16进制小写。
调用这个方法:
string strOrg = "中华人民共和国";
Console.WriteLine("md5 hash 16进制小写:"+ Md5Hash(strOrg));
看下结果:
md5 hash 16进制小写:025fceab9418be86066b60a71bc71485
我们也可以将"x2"换成大写的“X2”,这样转出来16进制字符串为大写。
public static String Md5HashUpper(String str)
{
MD5 md = MD5.Create();
byte[] bytes = Encoding.UTF8.GetBytes(str);
byte[] buffer2 = md.ComputeHash(bytes);
string rst = "";
//小写的 x2 是16进制小写。大写 X2 是转16进制大写。
for (int i = 0; i < buffer2.Length; i++)
{
rst = rst + buffer2[i].ToString("X2");
}
return rst;
}
调用:
Console.WriteLine("md5 hash 16进制大写:" + Md5HashUpper(strOrg));
结果 :
md5 hash 16进制大写:025FCEAB9418BE86066B60A71BC71485
还有另一个方法,可把byte[] 转为16进制:BitConverter.ToString().
要注意,BitConverter.ToString(),转出来的16进制字符串,是带减号的“-”,返回最终结果时要去掉-。
public static String Md5HashBitConvert(String str)
{
MD5 md = MD5.Create();
byte[] bytes = Encoding.UTF8.GetBytes(str);
byte[] buffer2 = md.ComputeHash(bytes);
string rst = BitConverter.ToString(buffer2);
Console.WriteLine("BitConverter.ToString()之后原始值:" + rst);
string rst2 = rst.Replace("-", "");
Console.WriteLine("去掉减号‘-’后值:" + rst2);
return rst2;
}
运算结果:
BitConverter.ToString()之后原始值:02-5F-CE-AB-94-18-BE-86-06-6B-60-A7-1B-C7-14-85
去掉减号‘-’后值:025FCEAB9418BE86066B60A71BC71485
三。JAVA
package org.example;
import java.security.MessageDigest;
public class HashUtil {
public static String Md5Hash(String str) throws Exception
{
//默认UTF8
byte[] byStr=str.getBytes();
String rst="";
// MessageDigest instance for MD5
MessageDigest md = MessageDigest.getInstance("MD5");
// Update MessageDigest with input text in bytes
md.update(byStr);
// Get the hashbytes
byte[] hashBytes = md.digest();
// Convert hash bytes to hex format
StringBuilder sc = new StringBuilder();
//小写的 x 是转16进制小写。
for (byte b : hashBytes) {
sc.append(String.format("%02x", b));
}
rst=sc.toString();
return rst;
}
public static String Md5HashUpper(String str) throws Exception
{
//默认UTF8
byte[] byStr=str.getBytes();
String rst="";
// MessageDigest instance for MD5
MessageDigest md = MessageDigest.getInstance("MD5");
// Update MessageDigest with input text in bytes
md.update(byStr);
// Get the hashbytes
byte[] hashBytes = md.digest();
// Convert hash bytes to hex format
StringBuilder sc = new StringBuilder();
//小写的 x 是转16进制小写。大写的 X 转为大写。
for (byte b : hashBytes) {
sc.append(String.format("%02X", b));
}
rst=sc.toString();
return rst;
}
}
调用:
public static void main( String[] args )
{
try { String md5HashInput="中华人民共和国";
System.out.println( "MD5 HASH输入:" +md5HashInput); String md5HashOutput=HashUtil.Md5HashUpper(md5HashInput); System.out.println( "MD5 HASH输出:" +md5HashOutput);
}catch (Exception ex)
{
System.out.println( "ex:"+ex.getMessage() );
} System.out.println( "Hello ee!" );
}
}
运算结果:
MD5 HASH输入:中华人民共和国
MD5 HASH输出:025FCEAB9418BE86066B60A71BC71485
没必要为了大小单独写一个方法,直接在 Md5Hash(strOrg) 方法后面加 ToUpper(),这里只是为了方便演示。
Console.WriteLine("md5 hash 16进制大写2 :" + Md5Hash(strOrg).ToUpper());
(编程语言界的丐帮 C#).NET MD5 HASH 哈希 加密 与JAVA 互通的更多相关文章
- 如何在C#中生成与PHP一样的MD5 Hash Code
最近在对一个现有的系统进行C#改造,该系统以前是用PHP做的,后台的管理员登陆用的是MD5加密算法.在PHP中,要对一个字符串进行MD5加密非常简单,一行代码即可: md5("Somethi ...
- C# 实现MD5 Hash 计算
C#提供了一系列的加密库,可以让我们自由使用,这里我来介绍如何使用C#的加密库实现MD5 hash值的计算工作. 参考代码: private static String CalcMd5(String ...
- md5是哈希算法的改进加强,因为不同原始值可能hash结果一样,但md5则改善了用于验证消息完整性,不同md5值原始值也必将不一样
md5是哈希算法的改进加强,因为不同原始值可能hash结果一样,但md5则改善了用于验证消息完整性,不同md5值原始值也必将不一样
- 哈希(Hash)与加密(Encrypt)相关内容
1.哈希(Hash)与加密(Encrypt)的区别 哈希(Hash)是将目标文本转换成具有相同长度的.不可逆的杂凑字符串(或叫做消息摘要),而加密(Encrypt)是将目标文本转换成具有不同长度的.可 ...
- Hash哈希(一)
Hash哈希(一) 哈希是大家比较常见一个词语,在编程中也经常用到,但是大多数人都是知其然而不知其所以然,再加上这几天想写一个一致性哈希算法,突然想想对哈希也不是很清楚,所以,抽点时间总结下Hash知 ...
- md5增加指定的加密规则,进行加密
import java.io.UnsupportedEncodingException; import java.security.MessageDigest; import java.securit ...
- MD5 SHA1 哈希 签名 碰撞 MD
Markdown版本笔记 我的GitHub首页 我的博客 我的微信 我的邮箱 MyAndroidBlogs baiqiantao baiqiantao bqt20094 baiqiantao@sina ...
- 第二百九十六节,python操作redis缓存-Hash哈希类型,可以理解为字典类型
第二百九十六节,python操作redis缓存-Hash哈希类型,可以理解为字典类型 Hash操作,redis中Hash在内存中的存储格式如下图: hset(name, key, value)name ...
- 上传图片用图片文件的对象hash哈希值判断图片是否一样,避免重复提交相同的图片到服务器中
上传图片用图片文件的对象hash哈希值判断图片是否一样,避免重复提交相同的图片到服务器中 前端:要用到一个插件,点击下载 <!DOCTYPE html> <html xmlns=&q ...
随机推荐
- 2022年字节跳动基础架构前端实习生凉经(4轮技术面+hr面)
技术一面 原文链接:https://juejin.cn/post/7120516854203809829 因为我之前的项目经验有开发小程序的,所以一开始就问了小程序的问题 1.小程序onload和on ...
- kube-shell安装
1.开源项目kube-shell可以为kubectl提供自动的命令提示和补全,对于初学kubernetes比较友好. https://github.com/cloudnativelabs/kube-s ...
- 6.4.2 用BFS求最短路
前面的篇幅占了太多,再次新开一章,讲述BFS求最短路的问题 注意此时DFS就没有BFS好用了,因为DFS更适合求全部解,而BFS适合求最优解 这边再次提醒拓扑变换的思想在图形辨认中的重要作用,需要找寻 ...
- 毫秒值的概念和作用与Date类的构造方法和成员方法
日期时间类 Date类 java.Util.Date:表示日期和实践类 类Date表示特定的瞬间,精确到毫秒 毫秒:千分之疫苗 1000毫秒 =1秒 特定的瞬间:一个时间点,一刹那使劲啊 2088-0 ...
- 手把手带你实现基于 Vite+Vue3 的在线Excel表格系统
今天,葡萄带你了解如何基于Vite+Vue3实现一套纯前端在线表格系统. 在正式开始项目介绍之前,首先咱们首先来介绍一下Vite和Vue3. Vue3 2020年09月18日Vue.js 3.0发布, ...
- 叫高二上一调?简要题解 (ACD)
A. 电压机制 题意转换为所有奇环的并排除掉所有偶环留下的边的个数 . 建出 DFS 树,然后只有返祖边可能构成环 . 于是类似树上差分,\(odd_u\) 统计奇环,\(even_u\) 统计偶环 ...
- axios&spring前后端分离传参规范总结
前后端分离开发的场景下,开发人员的工作内容更加专注与专业,但是也产生了一些额外的沟通成本.比如:本文中为大家说明的前后端参数传递与接受方法.本文主要是面对前端使用axios,后端使用Spring进行参 ...
- WPF 截图控件之文字(七)「仿微信」
前言 接着上周写的截图控件继续更新添加 文字. 1.WPF实现截屏「仿微信」 2.WPF 实现截屏控件之移动(二)「仿微信」 3.WPF 截图控件之伸缩(三) 「仿微信」 4.WPF 截图控件之绘制方 ...
- 解决前端向后端请求静态资源的问题(基于express框架)
请求js,css,image资源: 前端 <script src='后端url/assets/js/xxx.js'>,<link href='后端url/assets/css/xxx ...
- 未关中断情况下的hardlock
最近遇到一例crash,3.10内核,hardlock,查看对应的堆栈,中断是使能的. 查看对应的hrtimer_interrupts和hrtimer_interrupt_save的值,发现确实相等. ...