简体   繁体   中英

Azure Notification Hub error 401

Im having a bit of issue setting up a console application that will send push notifications to iOS/Android devices.

Error shown is below:

Unhandled Exception: System.AggregateException: One or more errors
occurred. ---System.UnauthorizedAccessException: The remote server
returned an error: (401)
Unauthorized..TrackingId:ea158550-8761-41f8-821d-dbcb88fcce56,TimeStamp:18/07/2016
08:58:21 ---System.Net.WebException: The remote server returned an
error: (401) Unauthorized.    at
System.Net.HttpWebRequest.EndGetResponse(IAsyncResult asyncResult)   
at
Microsoft.Azure.NotificationHubs.NotificationRequestAsyncResult`1.<GetAsyncSteps>b__3(TAsyncResult
thisPtr, IAsyncResult r)    at
Microsoft.Azure.NotificationHubs.Messaging.IteratorAsyncResult`1.StepCallback(IAsyncResult
result)    --- End of inner exception stack trace ---

Server stack trace:


Exception rethrown at [0]:    at
Microsoft.Azure.NotificationHubs.Common.AsyncResult.End[TAsyncResult](IAsyncResult
result)    at
Microsoft.Azure.NotificationHubs.NotificationHubManager.EndSendNotification(IAsyncResult
result)    at
System.Threading.Tasks.TaskFactory`1.FromAsyncCoreLogic(IAsyncResult
iar, Func`2 endFunction, Action`1 endAction, Task`1 promise, Boolean
requiresSynchronization)    --- End of inner exception stack trace ---
at System.Threading.Tasks.Task.ThrowIfExceptional(Boolean
includeTaskCanceledExceptions)    at
System.Threading.Tasks.Task.Wait(Int32 millisecondsTimeout,
CancellationToken cancellationToken)    at
System.Threading.Tasks.Task.Wait()    at
XamarinAzurePushNotification.Server.Program.Main(String[] args) in
B:\Personal Development\Visual Studio
2015\AzurePushNotifications\XamarinAzurePushNotification.Server\Program.cs:line
26

Here is my code for the console application:

private static void Main(string[] args)
{
    var hub = NotificationHubClient.CreateClientFromConnectionString("Endpoint=sb://ConnectionStringName.servicebus.windows.net/;SharedAccessKeyName=DefaultListenSharedAccessSignature;SharedAccessKey=ConnectionStringKey", "HubName");

    var iOS_alert = "{\"aps\":{\"alert\":\"Hello. This is a iOS notification! Tada!\", \"sound\":\"default\"}}";
    hub.SendAppleNativeNotificationAsync(iOS_alert).Wait();

    var android_alert = "{\"message\": \"Can I interest you in a once in a lifetime push notification?!\", \"title\":\"Ding, dong!\"}";
    hub.SendGcmNativeNotificationAsync(android_alert).Wait();

    Console.WriteLine("MESSAGE SENT");
}

If anyone could give me a hand with this it'd be great.

It looks like you are using the DefaultListenSharedAccessSignature ; instead use the DefaultFullSharedAccessSignature .

If any of the answers above did not work, please check if the server/PC has the correct Date Time configured. In my case, on a client, the server had wrong Date Time settings, and I got the Error:

Error Code: 0x17 System.AggregateException: One or more errors occurred. ---> System.UnauthorizedAccessException: The remote server returned an error: (401) Unauthorized. ExpiredToken: .TrackingId:4c2cdbg3-e1a8-4240-b963-d6f55e8f2c76_G29,TimeStamp:8/23/2018 8:58:27 AM ---> System.Net.WebException: The remote server returned an error: (401) Unauthorized. at System.Net.HttpWebRequest.EndGetResponse(IAsyncResult asyncResult) at Microsoft.Azure.NotificationHubs.NotificationRequestAsyncResult 1.<>c.<GetAsyncSteps>b__26_3(TAsyncResult thisPtr, IAsyncResult r) at Microsoft.Azure.NotificationHubs.Messaging.IteratorAsyncResult 1.StepCallback(IAsyncResult result) --- End of inner exception stack trace ---

Very frustrating until I found the problem.

The technical post webpages of this site follow the CC BY-SA 4.0 protocol. If you need to reprint, please indicate the site URL or the original address.Any question please contact:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM