0

MoonAPNSライブラリを使用して、Appleアプリの有効なトークンのリストを見つけようとしています。GetFeedBack()を使用している間、受信したトークンの数は数分後に大幅に変化します。最初の試行では約8000でした。その後、3回目の試行では1で、再び0でした。

有効な本番証明書で使用しています。&同じ証明書を使用して通知をサンプリングされたデバイスに正常にプッシュしました。

コードのロジックと、受け取ったトークンをどのような基準で提供しているのかわかりません。MoonAPNSからダウンロードしたコードは以下のとおりです。

public List<Feedback> GetFeedBack()
{
  try
  {
    var feedbacks = new List<Feedback>();
    Logger.Info("Connecting to feedback service.");

    if (!_conected)
        Connect(_feedbackHost, FeedbackPort, _certificates);

    if (_conected)
    {
        //Set up
        byte[] buffer = new byte[38];
        int recd = 0;
        DateTime minTimestamp = DateTime.Now.AddYears(-1);

        //Get the first feedback
        recd = _apnsStream.Read(buffer, 0, buffer.Length);
        Logger.Info("Feedback response received.");

        if (recd == 0)
            Logger.Info("Feedback response is empty.");

        //Continue while we have results and are not disposing
        while (recd > 0)
        {
            Logger.Info("processing feedback response");
            var fb = new Feedback();

            //Get our seconds since 1970 ?
            byte[] bSeconds = new byte[4];
            byte[] bDeviceToken = new byte[32];

            Array.Copy(buffer, 0, bSeconds, 0, 4);

            //Check endianness
            if (BitConverter.IsLittleEndian)
                Array.Reverse(bSeconds);

            int tSeconds = BitConverter.ToInt32(bSeconds, 0);

            //Add seconds since 1970 to that date, in UTC and then get it locally
            fb.Timestamp = new DateTime(1970, 1, 1, 0, 0, 0, DateTimeKind.Utc).AddSeconds(tSeconds).ToLocalTime();


            //Now copy out the device token
            Array.Copy(buffer, 6, bDeviceToken, 0, 32);

            fb.DeviceToken = BitConverter.ToString(bDeviceToken).Replace("-", "").ToLower().Trim();

            //Make sure we have a good feedback tuple
            if (fb.DeviceToken.Length == 64 && fb.Timestamp > minTimestamp)
            {
                //Raise event
                //this.Feedback(this, fb);
                feedbacks.Add(fb);
            }

            //Clear our array to reuse it
            Array.Clear(buffer, 0, buffer.Length);

            //Read the next feedback
            recd = _apnsStream.Read(buffer, 0, buffer.Length);
        }
        //clode the connection here !
        Disconnect();
        if (feedbacks.Count > 0)
            Logger.Info("Total {0} feedbacks received.", feedbacks.Count);
        return feedbacks;
    }
  }
  catch (Exception ex)
  {
    Logger.Error("Error occurred on receiving feed back. - " + ex.Message);
    return null;
  }
  return null;
}

}

4

1 に答える 1

1

個人的には Moon APNS を使用したことはありませんが、APNS フィードバック サービスのしくみは、呼び出すたびに、最後にフィードバック サービスを呼び出してから非アクティブなトークンを返します。そして、それはあなたがここで見ているパターンを説明しています.

于 2012-05-08T10:05:09.660 に答える