使用GCM在C#中发送推送通知 - 401未经授权

时间:2016-10-04 17:51:02

标签: c# google-cloud-messaging

我试图创建一个基于控制台的服务器应用程序,以便在本教程之后向Android客户端发送推送通知here

本教程有一个相当直接的代码,用于连接到GCM服务以向客户端发送通知,如下所示:

 public const string API_KEY = "AIzaS...jhqOydFCU";
    public const string MESSAGE = "Hello!";

    static void Main(string[] args)
    {
        var jGcmData = new JObject();
        var jData = new JObject();

        jData.Add("message", MESSAGE);
        jGcmData.Add("to", "/topics/global");
        jGcmData.Add("data", jData);

        var url = new Uri("https://gcm-http.googleapis.com/gcm/send");
        try
        {
            using (var client = new HttpClient())
            {
                client.DefaultRequestHeaders.Accept.Add(
                    new MediaTypeWithQualityHeaderValue("application/json"));

                client.DefaultRequestHeaders.TryAddWithoutValidation(
                    "Authorization", "key=" + API_KEY);

                Task.WaitAll(client.PostAsync(url,
                    new StringContent(jGcmData.ToString(), Encoding.Default, "application/json"))
                        .ContinueWith(response =>
                        {
                            Console.WriteLine(response);
                            Console.WriteLine("Message sent: check the client device notification tray.");
                        }));
            }
        }
        catch (Exception e)
        {
            Console.WriteLine("Unable to send GCM message:");
            Console.Error.WriteLine(e.StackTrace);
        }
    }

我从服务器的响应头中收到401未经授权的错误。我试过不同的API密钥,但结果是一样的。我不确定这是什么原因。我的客户端应用程序没有收到服务器发送的任何通知。

1 个答案:

答案 0 :(得分:0)

很高兴它已经为你工作了。

在以前的情况下,它是由不使用服务器密钥引起的。但是现在开发人员控制台已经更新,通常会观察开发人员尝试将API密钥限制(白名单)到您的Web服务和/或IP地址,并等待大约5分钟以使更改生效。

Only Server API keys适用于GCM / FCM。但是,随着开发人员控制台最近的变化,我可以建议将服务器称为白名单(本地/远程托管)。