0

我在集群模式中使用 akka.net。(n) 处理节点,目前有 1 个灯塔。

通过网络导航的软件包之一公开了语言信息。

    /// <summary>
/// Define scored a suite of token info
/// </summary>
/// <seealso cref="Hammer.Immutable.ImmutableObject" />
[DataContract]
public sealed class TokenSuite : ImmutableObject, IIdItem
{
    #region Ctor

    /// <summary>
    /// Initializes a new instance of the <see cref="TokenSuite"/> class.
    /// </summary>
    public TokenSuite(Guid id, string langCode)
        : base(id, langCode)
    {
        this.Id = id;
        this.LangCode = langCode;

        if (!string.IsNullOrEmpty(langCode))
            LangInfo = CultureInfo.GetCultureInfoByIetfLanguageTag(langCode);
    }

    #endregion

    #region Properties

    /// <summary>
    /// Gets the identifier.
    /// </summary>
    [DataMember]
    public Guid Id { get; }

    /// <summary>
    /// Gets the main language code.
    /// </summary>
    [DataMember]
    public string LangCode { get; }

    /// <summary>
    /// Gets the lang information.
    /// </summary>
    [IgnoreDataMember]
    public CultureInfo LangInfo { get; }


    #endregion

在本地没问题,但是当它通过网络(序列化)时,我在灯塔上遇到了这个问题: 灯塔问题

读取错误似乎来自 CultureInfo 对象,但它是序列化中要忽略的标志。

我使用 Akka 版本 1.3.5、Hyperion 0.9.8、Akka.Serialization.Hyperion 1.3.2-beta54。

我尝试在本地序列化并且它有效:

var serializer = Context.System.Serialization.FindSerializerForType(typeof(TokenSuite));
var data = serializer.ToBinary(result);
var rtoObjectBack = serializer.FromBinary<TokenSuite>(data);

任何想法 ?

4

1 回答 1

1

Hyperion 不使用任何数据合同属性。这也意味着[IgnoreDataMember]不会被考虑在内。

CultureInfo您提供的尝试反序列化对象时可能会失败。您始终可以尝试将其转换为字符串,并在反序列化后解析。

于 2018-03-06T10:25:37.963 回答