RError.com

RError.com Logo RError.com Logo

RError.com Navigation

  • 主页

Mobile menu

Close
  • 主页
  • 系统&网络
    • 热门问题
    • 最新问题
    • 标签
  • Ubuntu
    • 热门问题
    • 最新问题
    • 标签
  • 帮助
主页 / 问题 / 1538722
Accepted
GoodBoyAlex
GoodBoyAlex
Asked:2023-09-02 04:05:31 +0000 UTC2023-09-02 04:05:31 +0000 UTC 2023-09-02 04:05:31 +0000 UTC

FormatException:加密文本时输入不是有效的 Base-64 字符串错误

  • 772

有一个关键类:

public class EncryptKey
{
    public EncryptKey (byte[] key) => Key = key;

    public EncryptKey (string key) => FromString(key);

    public byte[] Key { get; set; }

    public void FromString (string s)
    {
        using SymmetricAlgorithm sa = Aes.Create();

        using Rfc2898DeriveBytes hasher = new(s, sa.IV, 5000, HashAlgorithmName.SHA512);

        Key = hasher.GetBytes(32);
    }

    public override string ToString() => Convert.ToBase64String(Key);
}

加密实现如下所示:

public static string Encrypt (string text, IEncryptKey key)
{
    string textToEncode = text.Replace("/", "%SL%").Replace("+", "%PL%");

    using Aes aes = Aes.Create();

    aes.Key = key.Key;

    using MemoryStream ms = new();

    ms.Write(aes.IV);

    using (CryptoStream cs = new(ms, aes.CreateEncryptor(), CryptoStreamMode.Write, true))

        cs.Write(Encoding.UTF8.GetBytes(textToEncode));

    return Convert.ToBase64String(ms.ToArray());
}

public static string Decrypt (string text, IEncryptKey key)
{
    string textToDecode = text.Replace("%SL%", "/").Replace("%PL%", "+");

    using MemoryStream ms = new(Convert.FromBase64String(textToDecode));

    byte[] iv = new byte[16];

    _ = ms.Read(iv);

    using Aes aes = Aes.Create();

    aes.Key = key.Key;

    aes.IV = iv;

    using CryptoStream cs = new(ms, aes.CreateDecryptor(), CryptoStreamMode.Read, true);

    using MemoryStream output = new();

    cs.CopyTo(output);

    return Encoding.UTF8.GetString(output.ToArray());
}

我这样称呼:

var encText = Encrypt(Guid.NewGuid().ToString, new("123"));
var decText = Decrypt(encText, new("123"));

结果,出现错误:

FormatException: The input is not a valid Base-64 string as it contains a non-base 64 character, more than two padding characters, or an illegal character among the padding characters
c#
  • 1 1 个回答
  • 47 Views

1 个回答

  • Voted
  1. Best Answer
    aepot
    2023-09-02T04:46:04Z2023-09-02T04:46:04Z

    对密码进行哈希处理时,IV 不应随意使用,而应使用相同的值。也就是说,加密时使用哪个IV,解密时也应该使用相同的IV。

    嗯,他们在课程上很聪明,此外,将密钥永久存储在内存中对于安全来说是一个坏兆头。5000 次迭代 - 剥夺不会增加可靠性的工作。对 256 位密钥使用 512 位哈希值也不好。

    凡事适度就好。即使知道盐的人也无法对密码进行哈希处理,即使经过哈希处理、重新哈希 1000 次甚至更多次。阅读RFC 2898。

    private static byte[] KeyFromString(string s, byte[] salt)
    {
        using Rfc2898DeriveBytes hasher = new(s, salt, 1000, HashAlgorithmName.SHA256);
        return hasher.GetBytes(32);
    }
    
    public static string Encrypt(string text, string password)
    {
        using Aes aes = Aes.Create();
        aes.Key = KeyFromString(password, aes.IV);
        using MemoryStream ms = new();
        ms.Write(aes.IV);
        using (CryptoStream cs = new(ms, aes.CreateEncryptor(), CryptoStreamMode.Write, true))
            cs.Write(Encoding.UTF8.GetBytes(text));
        return Convert.ToBase64String(ms.ToArray());
    }
    
    public static string Decrypt(string base64, string password)
    {
        using MemoryStream ms = new(Convert.FromBase64String(base64));
        byte[] iv = new byte[16];
        ms.Read(iv);
        using Aes aes = Aes.Create();
        aes.Key = KeyFromString(password, iv);
        aes.IV = iv;
        using CryptoStream cs = new(ms, aes.CreateDecryptor(), CryptoStreamMode.Read, true);
        using MemoryStream output = new();
        cs.CopyTo(output);
        return Encoding.UTF8.GetString(output.ToArray());
    }
    

    如果需要Base64 URL格式,那么可以按照标准进行转换

    public static string Base64UrlEncode(string base64)
    {
        return base64.TrimEnd('=').Replace('+', '-').Replace('/', '_');
    }
    
    public static string Base64UrlDecode(string base64)
    {
        string result = base64.Replace('_', '/').Replace('-', '+');
        if (result.Length % 4 == 2)
            result += "==";
        else
        if (result.Length % 4 == 3)
            result += "=";
        return result;
    }
    

    尽量不要在一种方法中混合多种不同类型的问题。该方法必须做一件事。


    string text = "Hello World!";
    string password = "qwe123";
    string base64 = Encrypt(text, password);
    Console.WriteLine(base64);
    string urlSafeBase64 = Base64UrlEncode(base64);
    Console.WriteLine(urlSafeBase64);
    
    string base64decoded = Base64UrlDecode(urlSafeBase64);
    string textDecrypted = Decrypt(base64decoded, password);
    Console.WriteLine(textDecrypted);
    

    输出到控制台(每次输出不同的base64,但应该是这样)

    +SslYF2B/sNcZzYZ2f6dGrNMPv0EHgld5+buiAVWyCM=
    -SslYF2B_sNcZzYZ2f6dGrNMPv0EHgld5-buiAVWyCM
    Hello World!
    

    现在,当它工作时,您已经可以在其上包装抽象、类和其他 OOP。祝你好运!

    • 2

相关问题

  • 使用嵌套类导出 xml 文件

  • 分层数据模板 [WPF]

  • 如何在 WPF 中为 ListView 手动创建列?

  • 在 2D 空间中,Collider 2D 挂在玩家身上,它对敌人的重量相同,我需要它这样当它们碰撞时,它们不会飞向不同的方向。统一

  • 如何在 c# 中使用 python 神经网络来创建语音合成?

  • 如何知道类中的方法是否属于接口?

Sidebar

Stats

  • 问题 10021
  • Answers 30001
  • 最佳答案 8000
  • 用户 6900
  • 常问
  • 回答
  • Marko Smith

    我看不懂措辞

    • 1 个回答
  • Marko Smith

    请求的模块“del”不提供名为“default”的导出

    • 3 个回答
  • Marko Smith

    "!+tab" 在 HTML 的 vs 代码中不起作用

    • 5 个回答
  • Marko Smith

    我正在尝试解决“猜词”的问题。Python

    • 2 个回答
  • Marko Smith

    可以使用哪些命令将当前指针移动到指定的提交而不更改工作目录中的文件?

    • 1 个回答
  • Marko Smith

    Python解析野莓

    • 1 个回答
  • Marko Smith

    问题:“警告:检查最新版本的 pip 时出错。”

    • 2 个回答
  • Marko Smith

    帮助编写一个用值填充变量的循环。解决这个问题

    • 2 个回答
  • Marko Smith

    尽管依赖数组为空,但在渲染上调用了 2 次 useEffect

    • 2 个回答
  • Marko Smith

    数据不通过 Telegram.WebApp.sendData 发送

    • 1 个回答
  • Martin Hope
    Alexandr_TT 2020年新年大赛! 2020-12-20 18:20:21 +0000 UTC
  • Martin Hope
    Alexandr_TT 圣诞树动画 2020-12-23 00:38:08 +0000 UTC
  • Martin Hope
    Air 究竟是什么标识了网站访问者? 2020-11-03 15:49:20 +0000 UTC
  • Martin Hope
    Qwertiy 号码显示 9223372036854775807 2020-07-11 18:16:49 +0000 UTC
  • Martin Hope
    user216109 如何为黑客设下陷阱,或充分击退攻击? 2020-05-10 02:22:52 +0000 UTC
  • Martin Hope
    Qwertiy 并变成3个无穷大 2020-11-06 07:15:57 +0000 UTC
  • Martin Hope
    koks_rs 什么是样板代码? 2020-10-27 15:43:19 +0000 UTC
  • Martin Hope
    Sirop4ik 向 git 提交发布的正确方法是什么? 2020-10-05 00:02:00 +0000 UTC
  • Martin Hope
    faoxis 为什么在这么多示例中函数都称为 foo? 2020-08-15 04:42:49 +0000 UTC
  • Martin Hope
    Pavel Mayorov 如何从事件或回调函数中返回值?或者至少等他们完成。 2020-08-11 16:49:28 +0000 UTC

热门标签

javascript python java php c# c++ html android jquery mysql

Explore

  • 主页
  • 问题
    • 热门问题
    • 最新问题
  • 标签
  • 帮助

Footer

RError.com

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

帮助

© 2023 RError.com All Rights Reserve   沪ICP备12040472号-5