在 Blazor WASM 中手撸一个.NET MD5类

2024-02-10 16:44
文章标签 net md5 wasm blazor 中手

本文主要是介绍在 Blazor WASM 中手撸一个.NET MD5类,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

最近.net8 blazor auto大火, 我也玩了一下,发现ssr能用的代码 MD5 类在wasm是没法用的. 于是搜索了一下互联网,找到了一份代码,分享给大家.

我找到的帖子作者原话: 代码不是我的,但我确实稍微修改了它以使其与 System.Security.Cryptography.MD5 类更加一致。

public static class MD5
{public static byte[] ComputeHash(byte[] input){uint num = 1732584193u;uint num2 = 4023233417u;uint num3 = 2562383102u;uint num4 = 271733878u;int num5 = (56 - (input.Length + 1) % 64) % 64;byte[] array = new byte[input.Length + 1 + num5 + 8];Array.Copy(input, array, input.Length);array[input.Length] = 128;Array.Copy(BitConverter.GetBytes(input.Length * 8), 0, array, array.Length - 8, 4);for (int i = 0; i < array.Length / 64; i++){uint[] array2 = new uint[16];for (int j = 0; j < 16; j++){array2[j] = BitConverter.ToUInt32(array, i * 64 + j * 4);}uint num6 = num;uint num7 = num2;uint num8 = num3;uint num9 = num4;uint num10 = 0u;uint num11 = 0u;uint num12 = 0u;while (true){switch (num12){case 0u:case 1u:case 2u:case 3u:case 4u:case 5u:case 6u:case 7u:case 8u:case 9u:case 10u:case 11u:case 12u:case 13u:case 14u:case 15u:num10 = num7 & num8 | ~num7 & num9;num11 = num12;goto IL_0138;case 16u:case 17u:case 18u:case 19u:case 20u:case 21u:case 22u:case 23u:case 24u:case 25u:case 26u:case 27u:case 28u:case 29u:case 30u:case 31u:case 32u:case 33u:case 34u:case 35u:case 36u:case 37u:case 38u:case 39u:case 40u:case 41u:case 42u:case 43u:case 44u:case 45u:case 46u:case 47u:case 48u:case 49u:case 50u:case 51u:case 52u:case 53u:case 54u:case 55u:case 56u:case 57u:case 58u:case 59u:case 60u:case 61u:case 62u:case 63u:if (num12 >= 16 && num12 <= 31){num10 = num9 & num7 | ~num9 & num8;num11 = (5 * num12 + 1) % 16u;}else if (num12 >= 32 && num12 <= 47){num10 = num7 ^ num8 ^ num9;num11 = (3 * num12 + 5) % 16u;}else if (num12 >= 48){num10 = num8 ^ (num7 | ~num9);num11 = 7 * num12 % 16u;}goto IL_0138;}break;IL_0138:uint num13 = num9;num9 = num8;num8 = num7;num7 += leftRotate(num6 + num10 + K[num12] + array2[num11], s[num12]);num6 = num13;num12++;}num += num6;num2 += num7;num3 += num8;num4 += num9;}var hashBytes = new byte[16];BitConverter.GetBytes(num).CopyTo(hashBytes, 0);BitConverter.GetBytes(num2).CopyTo(hashBytes, 4);BitConverter.GetBytes(num3).CopyTo(hashBytes, 8);BitConverter.GetBytes(num4).CopyTo(hashBytes, 12);return hashBytes;}public static string ComputeHashString(byte[] input) => string.Join("", ComputeHash(input).Select(o => o.ToString("x2")));private static int[] s = new int[64]{7, 12, 17, 22, 7, 12, 17, 22, 7, 12,17, 22, 7, 12, 17, 22, 5, 9, 14, 20,5, 9, 14, 20, 5, 9, 14, 20, 5, 9,14, 20, 4, 11, 16, 23, 4, 11, 16, 23,4, 11, 16, 23, 4, 11, 16, 23, 6, 10,15, 21, 6, 10, 15, 21, 6, 10, 15, 21,6, 10, 15, 21};private static uint[] K = new uint[64]{3614090360u, 3905402710u, 606105819u, 3250441966u, 4118548399u, 1200080426u, 2821735955u, 4249261313u, 1770035416u, 2336552879u,4294925233u, 2304563134u, 1804603682u, 4254626195u, 2792965006u, 1236535329u, 4129170786u, 3225465664u, 643717713u, 3921069994u,3593408605u, 38016083u, 3634488961u, 3889429448u, 568446438u, 3275163606u, 4107603335u, 1163531501u, 2850285829u, 4243563512u,1735328473u, 2368359562u, 4294588738u, 2272392833u, 1839030562u, 4259657740u, 2763975236u, 1272893353u, 4139469664u, 3200236656u,681279174u, 3936430074u, 3572445317u, 76029189u, 3654602809u, 3873151461u, 530742520u, 3299628645u, 4096336452u, 1126891415u,2878612391u, 4237533241u, 1700485571u, 2399980690u, 4293915773u, 2240044497u, 1873313359u, 4264355552u, 2734768916u, 1309151649u,4149444226u, 3174756917u, 718787259u, 3951481745u};private static uint leftRotate(uint x, int c){return x << c | x >> 32 - c;}
}

不得不说,真香.

参考来源

https://stackoverflow.com/questions/76728300/any-net-md5-library-nuget-for-blazor-webassembly

这篇关于在 Blazor WASM 中手撸一个.NET MD5类的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/697589

相关文章

poj 1258 Agri-Net(最小生成树模板代码)

感觉用这题来当模板更适合。 题意就是给你邻接矩阵求最小生成树啦。~ prim代码:效率很高。172k...0ms。 #include<stdio.h>#include<algorithm>using namespace std;const int MaxN = 101;const int INF = 0x3f3f3f3f;int g[MaxN][MaxN];int n

如何在Visual Studio中调试.NET源码

今天偶然在看别人代码时,发现在他的代码里使用了Any判断List<T>是否为空。 我一般的做法是先判断是否为null,再判断Count。 看了一下Count的源码如下: 1 [__DynamicallyInvokable]2 public int Count3 {4 [__DynamicallyInvokable]5 get

2、PF-Net点云补全

2、PF-Net 点云补全 PF-Net论文链接:PF-Net PF-Net (Point Fractal Network for 3D Point Cloud Completion)是一种专门为三维点云补全设计的深度学习模型。点云补全实际上和图片补全是一个逻辑,都是采用GAN模型的思想来进行补全,在图片补全中,将部分像素点删除并且标记,然后卷积特征提取预测、判别器判别,来训练模型,生成的像

C# Hash算法之MD5、SHA

MD5我们用的还是比较多的,一般用来加密存储密码。但是现在很多人觉MD5可能不太安全了,所以都用上了SHA256等来做加密(虽然我觉得都差不多,MD5还是能玩)。 还是跟上一篇说的一样,当一个算法的复杂度提高的同时肯定会带来效率的降低,所以SHA和MD5比较起来的话,SHA更安全,MD5更高效。 由于HASH算法的不可逆性,所以我认为MD5和SHA主要还是应用在字符串的"加密"上。 由于

Android的登陆MD5加密

1:导入代码 public class MD5Util {private static final String TAG = "MD5Util";/**** MD5加码 生成32位md5码*/public static String string2MD5(String inStr) {Log.e(TAG, "string2MD5: -------------------------");Mess

.NET 自定义过滤器 - ActionFilterAttribute

这个代码片段定义了一个自定义的 ASP.NET Core 过滤器(GuardModelStateAttribute),用于在控制器动作执行之前验证模型状态(ModelState)。如果模型状态无效,则构造一个 ProblemDetails 对象来描述错误,并返回一个 BadRequest 响应。 代码片段: /// <summary>/// 验证 ModelState 是否有效/// </

.Net Mvc-导出PDF-思路方案

效果图: 导语:     在我们做项目的过程中,经常会遇到一些服务性的需求,感到特别困扰,明明实用的价值不高,但是还是得实现;     因此小客在这里整理一下自己导出PDF的一些思路,供大家参考。     网上有很多导出PDF运用到的插件,大家也可以看看其他插件的使用,学习学习; 提要:     这里我使用的是-iTextSharp,供大家参考参考,借鉴方案,完善思路,补充自己,一起学习

.net MVC 导出Word--思路详解

序言:          一般在项目的开发过程中,总会接收到一个个需求,其中将数据转换成Work来下载,是一个很常见的需求;          那么,我们改如何处理这种需求,并输出实现呢?          在做的过程中,去思考 1、第一步:首先确认,Work的存在位置,并创建字符输出路:             //在的项目中创建一个存储work的文件夹             string

asp.net 中GridView的使用方法

可以看看,学习学习 https://blog.csdn.net/zou15093087438/article/details/79637042

ASP.NET状态管理的总结

由于HTTP协议的无状态特性,导致在ASP.NET编程中,每个请求都会在服务端从头到执行一次管线过程, 对于ASP.NET页面来说,Page对象都会重新创建,所有控件以及内容都会重新生成, 因此,如果希望上一次的页面状态能够在后续页面中保留,则必需引入状态管理功能。   ASP.NET为了实现状态管理功能,提供了8种方法,可帮助我们在页面之间或者整个用户会话期间保留状态数据。 这些方法分为二类: