我想将对象序列化为字符串,然后返回。

我们使用protobuf-net成功地将一个对象转换成一个流。

然而,流到字符串和返回…不太成功。在经过StreamToString和StringToStream之后,新的stream不是 通过protobuf-net反序列化;它会引发算术操作,导致溢出异常。如果我们反序列化原始流,它就可以工作。

我们的方法:

public static string StreamToString(Stream stream)
{
    stream.Position = 0;
    using (StreamReader reader = new StreamReader(stream, Encoding.UTF8))
    {
        return reader.ReadToEnd();
    }
}

public static Stream StringToStream(string src)
{
    byte[] byteArray = Encoding.UTF8.GetBytes(src);
    return new MemoryStream(byteArray);
}

我们的示例代码使用这两个:

MemoryStream stream = new MemoryStream();
Serializer.Serialize<SuperExample>(stream, test);
stream.Position = 0;
string strout = StreamToString(stream);
MemoryStream result = (MemoryStream)StringToStream(strout);
var other = Serializer.Deserialize<SuperExample>(result);

当前回答

当你测试尝试UTF8编码流如下

var stream = new MemoryStream();
var streamWriter = new StreamWriter(stream, System.Text.Encoding.UTF8);
Serializer.Serialize<SuperExample>(streamWriter, test);

其他回答

UTF8内存流到字符串的转换:

var res = Encoding.UTF8.GetString(stream.GetBuffer(), 0 , (int)stream.Length)
 StreamReader reader = new StreamReader(strm, System.Text.Encoding.UTF8);
        var final1 = reader.ReadToEnd();

大多数问题的主要原因是编码类型…这里默认为System.Text.Encoding。UTF8修复了这个问题…

享受……

试试这个。

string output1 = Encoding.ASCII.GetString(byteArray, 0, byteArray.Length)

这很常见,但却大错特错。Protobuf数据不是字符串数据。它当然不是ASCII码。您正在反向使用编码。一个文本编码传输:

格式化字节的任意字符串 格式化字节到原始字符串

你没有“格式化字节”。你有任意的字节。您需要使用base-n(通常为base-64)之类的编码。这个转移

格式化字符串的任意字节 原始字节的格式化字符串

看看Convert。ToBase64String和Convert.FromBase64String。

我想将对象序列化为字符串,然后返回。

与其他答案不同,但对大多数对象类型来说,最直接的方法是XmlSerializer:

        Subject subject = new Subject();
        XmlSerializer serializer = new XmlSerializer(typeof(Subject));
        using (Stream stream = new MemoryStream())
        {
            serializer.Serialize(stream, subject);
            // do something with stream
            Subject subject2 = (Subject)serializer.Deserialize(stream);
            // do something with subject2
        }

所有受支持类型的公共属性都将被序列化。甚至支持一些集合结构,并将隧道向下到子对象属性。您可以控制属性上的属性的序列化工作方式。

这并不适用于所有对象类型,一些数据类型不支持序列化,但总的来说它是非常强大的,并且您不必担心编码。