Convert.ToBase64String和Convert.FromBase64String是C#中最直接、轻量的Base64编解码方法,适用于内存中byte[]数据,需注意UTF-8编码转换、非标准字符串清理、大文件流式处理及URL/JSON兼容性问题。
Convert.ToBase64String 和 Convert.FromBase64String 最直接这两个静态方法是 C# 中最常用、最轻量的 Base64 编解码方式,适用于内存中已有的 byte[] 数据。不需要额外引用,System 命名空间自带。
FormatException
Encoding.UTF8.GetBytes() 转成字节数组再编码string original = "Hello 世界"; byte[] bytes = Encoding.UTF8.GetBytes(original); string encoded = Convert.ToBase64String(bytes); // "SGVsbG8g5L2g5aW9"byte[] decodedBytes = Convert.FromBase64String(encoded); string decoded = Encoding.UTF8.GetString(decodedBytes); // "Hello 世界"
HTTP 查询参数或文件内容里常出现带换行、空格或用 -/_ 替代 +// 的变体(即 Base64Url 编码),Convert.FromBase64String 会直接报错。
.Replace(" ", "").Replace("\r", "").Replace("\n", "") 去掉空白-→+、_→/,再补足等号(长度需是 4 的倍数)=;例如长度 31 → 补 1 个 =
string urlSafe = "SGVsbG8g5L2g5aW9"; // 普通 Base64 // 若是 Base64Url:"SGVsbG8g5L2g5aW9" → 实际可能写成 "SGVsbG8g5L2g5aW9" string padded = urlSafe.PadRight(urlSafe.Length + (4 - urlSafe.Length % 4) % 4, '='); byte[] result = Convert.FromBase64String(padded);
对几 MB 以上的文件直接用 File.ReadAllBytes + Convert.ToBase64String 容易触发 GC 压力甚至 OutOfMemoryException。应改用流式处理。
StreamReader 读原文本块,逐段转 byte[] 再编码,拼接字符串(注意不要用 +=)System.Security.Cryptography.CryptoStream 配合 FromBase64Transform / ToBase64Transform,但它们已标记为 [Obsolete],仅限 .NET FrameworkSystem.IO.Stream + 自定义缓冲区,或借助第三方库如 Microsoft.Toolkit.HighPerformance 的 Base6
4.EncodeToUtf8
Base64 编码会使体积膨胀约 33%(每 3 字节 → 4 字符),且默认含 +、/、=,在 URL 或 JSON 中需额外处理。
+→-,/→_,去掉末尾 =)+// 合法,但某些旧解析器会误判;建议统一用 Base64Url 变体真正容易被忽略的是:不同平台对 Base64 填充等号的容忍度不一,有些库允许省略,有些强制要求。生产环境建议始终补全并验证格式,而不是依赖“看起来差不多”。