当前位置: 首页 > 编程笔记 >

.net core使用MD5加密解密字符串

仲孙诚
2023-03-14
本文向大家介绍.net core使用MD5加密解密字符串,包括了.net core使用MD5加密解密字符串的使用技巧和注意事项,需要的朋友参考一下

本文实例为大家分享了.net core使用MD5加密解密字符串的具体代码,供大家参考,具体内容如下

/// <summary>
    /// 加密
    /// </summary>
    /// <param name="Text">要加密的文本</param>
    /// <param name="sKey">秘钥</param>
    /// <returns></returns>
    public static string Encrypt(string Text, string sKey="test")
    {
      DESCryptoServiceProvider des = new DESCryptoServiceProvider();
      byte[] inputByteArray;
      inputByteArray = Encoding.Default.GetBytes(Text);
      des.Key = ASCIIEncoding.ASCII.GetBytes(Md5Hash(sKey).Substring(0,8));
      des.IV = ASCIIEncoding.ASCII.GetBytes(Md5Hash(sKey).Substring(0, 8));
      System.IO.MemoryStream ms = new System.IO.MemoryStream();
      CryptoStream cs = new CryptoStream(ms, des.CreateEncryptor(), CryptoStreamMode.Write);
      cs.Write(inputByteArray, 0, inputByteArray.Length);
      cs.FlushFinalBlock();
      StringBuilder ret = new StringBuilder();
      foreach (byte b in ms.ToArray())
      {
        ret.AppendFormat("{0:X2}", b);
      }
      md4j= ret.ToString();
      return ret.ToString();
    }

/// <summary>
    /// 解密
    /// </summary>
    /// <param name="Text"></param>
    /// <param name="sKey"></param>
    /// <returns></returns>
    public static string Decrypt(string Text, string sKey = "test")
    {
      DESCryptoServiceProvider des = new DESCryptoServiceProvider();
      int len;
      len = Text.Length / 2;
      byte[] inputByteArray = new byte[len];
      int x, i;
      for (x = 0; x < len; x++)
      {
        i = Convert.ToInt32(Text.Substring(x * 2, 2), 16);
        inputByteArray[x] = (byte)i;
      }
      des.Key = ASCIIEncoding.ASCII.GetBytes(Md5Hash(sKey).Substring(0, 8));
      des.IV = ASCIIEncoding.ASCII.GetBytes(Md5Hash(sKey).Substring(0, 8));
      System.IO.MemoryStream ms = new System.IO.MemoryStream();
      CryptoStream cs = new CryptoStream(ms, des.CreateDecryptor(), CryptoStreamMode.Write);
      cs.Write(inputByteArray, 0, inputByteArray.Length);
      cs.FlushFinalBlock();
      return Encoding.Default.GetString(ms.ToArray());
    }

/// <summary>
    /// 32位MD5加密
    /// </summary>
    /// <param name="input"></param>
    /// <returns></returns>
    private static string Md5Hash(string input)
    {
      MD5CryptoServiceProvider md5Hasher = new MD5CryptoServiceProvider();
      byte[] data = md5Hasher.ComputeHash(Encoding.Default.GetBytes(input));
      StringBuilder sBuilder = new StringBuilder();
      for (int i = 0; i < data.Length; i++)
      {
        sBuilder.Append(data[i].ToString("x2"));
      }
      return sBuilder.ToString();
    }

调用加密 解密看效果

public static string md4j = "";
static void Main(string[] args)
  {
      //加密
     Encrypt("123456");
     Decrypt(md4j);
 }

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持小牛知识库。

 类似资料:
  • 本文向大家介绍Python使用MD5加密字符串示例,包括了Python使用MD5加密字符串示例的使用技巧和注意事项,需要的朋友参考一下 Python加密模块有好几个,但无论是哪种加密方式都需要先导入相应的加密模块然后再使用模块对字符串加密。 先导入md5加密所需模块: 创建md5对象 生成加密串,其中 password 是要加密的字符串 获取加密串 输出 执行: 为了方便,我们可以写成函数,直接传

  • 问题内容: 我正在使用ExtJS框架。我在 JavaScript中 有MD5函数来加密某些JSON。我的后端使用Java,所以我想知道如何使用 Java 解密MD5 Javascript加密? 这是我正在使用的MD5函数的JS等效项: 问题答案: MD5是 哈希 (即单向转换),因此您无法对其进行解密。您可以将已知哈希与从明文计算出的哈希进行比较,以验证输入的有效性。Java已经为此内置了库。我在

  • 我想使用chacha20解密和加密字符串 BouncyCastleProvider正在使用chacha20技术。所以我包括了罐子。并尝试了代码,但无法工作。 pbe.java

  • 该md5加密方法,需要手动import库函数,调用md5方法即可使用,可以对字符串加密为32位的字符串结果,如需进一步了解, 详见MD5百度百科 使用方法: import md5Libs from "uview-ui/libs/function/md5"; export default{ onLoad() { console.log(md5Libs.md5('uView')) // 结果

  • 本文向大家介绍.NET MD5加密解密代码解析,包括了.NET MD5加密解密代码解析的使用技巧和注意事项,需要的朋友参考一下 MD5简介:   是让大容量信息在用数字签名软件签署私人密匙前被"压缩"成一种保密的格式(就是把一个任意长度的字节串变换成一定长的大整数)。不管是MD2、MD4还是MD5,它们都需要获得一个随机长度的信息并产生一个128位的信息摘要。虽然这些算法的结构或多或少有些相似,但

  • 我的代码如下: 有人来帮我吗