为什么我的C#转义字符在从base 64解码时不起作用?

时间:2017-09-02 04:13:04

标签: c# stringescapeutils

我制作了一个简单的打印应用,我使用\n\t来制作文字格式,例如制表符或换行符。

当我使用这样的硬编码输入时,它运行得很好。

isi = "ARIEF - JL. ANGGA JAYA II\n\t\t\t\tSTRUK PEMBAYARAN NEXXT MEDIA\n\nIDPEL\t\t\t: 09343590348509435\nTGL. BAYAR\t\t: 2017-09-02 10:26:53 \t\t\tTAGIHAN\t: 1.000.000\nPRODUK\t\t:\t\t\t\t\tADMIN\t\t: 2.500\nNAMA\t\t\t: RYAN\t\t\t\t\tTOTAL\t\t: 1.500.000\nREF\t\t\t: ARIEF - JL. ANGGA JAYA II\n\n\t\t\tCATUR TUNGGAL KAB SLEMAN DAISTA YOGYAKARTA\n\n\t\t\tSTRUK INI MERUPAKAN BUKTI PEMBAYARAN YANG SAH\n\t\t\t     HUBUNGI CUSTOMER SUPPORT LOKET PPOB ANDA\n";

并运行如下:

enter image description here

但是当我使用以下代码从base64解码中获取字符串时:

public string base64ToString(string str)
{
    byte[] data = Convert.FromBase64String(str);
    return Encoding.UTF8.GetString(data).ToString();
}

它不再格式化并获得此布局:

enter image description here

我的代码有问题吗?或者我错过了一些基本的C#知识?

这是UTF-8 base64编码的字符串:

QVJJRUYgLSBKTC4gQU5HR0EgSkFZQSBJSVxuXHRcdFx0XHRTVFJVSyBQRU1CQVlBUkFOIE5FWFhUIE1FRElBXG5cbklEUEVMXHRcdFx0OiAwOTM0MzU5MDM0ODUwOTQzNVxuVEdMLiBCQVlBUlx0XHQ6IDIwMTctMDktMDIgMTA6MjY6NTMgXHRcdFx0VEFHSUhBTlx0OiAxLjAwMC4wMDBcblBST0RVS1x0XHQ6XHRcdFx0XHRcdEFETUlOXHRcdDogMi41MDBcbk5BTUFcdFx0XHQ6IFJZQU5cdFx0XHRcdFx0VE9UQUxcdFx0OiAxLjUwMC4wMDBcblJFRlx0XHRcdDogQVJJRUYgLSBKTC4gQU5HR0EgSkFZQSBJSVxuXG5cdFx0XHRDQVRVUiBUVU5HR0FMIEtBQiBTTEVNQU4gREFJU1RBIFlPR1lBS0FSVEFcblxuXHRcdFx0U1RSVUsgSU5JIE1FUlVQQUtBTiBCVUtUSSBQRU1CQVlBUkFOIFlBTkcgU0FIXG5cdFx0XHRIVUJVTkdJIENVU1RPTUVSIFNVUFBPUlQgTE9LRVQgUFBPQiBBTkRBXG4=

我使用了这个字符串:

enter image description here

1 个答案:

答案 0 :(得分:1)

您使用的工具不适合工作。它将您粘贴的文字文本(反斜杠和全部)转换为base64字符串。从程序员的角度来看,它将\n更改为"\\n"。要使该工具正常工作,您无法输入\n并希望看到换行符,您需要实际输入换行符。对于\t,您需要键入实际的制表符(假设该工具不对数据执行任何其他处理)。

在代码中对它进行编码会更容易。

string EncodeString(string str, Encoding encoding = null)
{
    encoding = encoding ?? Encoding.UTF8;
    return Convert.ToBase64String(encoding.GetBytes(str));
}
string DecodeString(string str, Encoding encoding = null)
{
    encoding = encoding ?? Encoding.UTF8;
    return encoding.GetString(Convert.FromBase64String(str));
}