AspNetCore.Docs/aspnetcore/signalr/troubleshoot.md

94 lines
3.6 KiB
Markdown

---
title: ASP.NET Core SignalR connection troubleshooting
author: bradygaster
description: ASP.NET Core SignalR connection troubleshooting.
monikerRange: '>= aspnetcore-2.1'
ms.author: bradyg
ms.custom: mvc
ms.date: 04/08/2020
uid: signalr/troubleshoot
---
# Troubleshoot connection errors
This section provides help with errors that can occur when trying to establish a connection to an ASP.NET Core SignalR hub.
### Response code 404
When using WebSockets and `skipNegotiation = true`
```log
WebSocket connection to 'wss://xxx/HubName' failed: Error during WebSocket handshake: Unexpected response code: 404
```
* When using multiple servers without sticky sessions, the connection can start on one server and then switch to another server. The other server is not aware of the previous connection.
* Verify the client is connecting to the correct endpoint. For example, the server is hosted at `http://127.0.0.1:5000/hub/myHub` and client is trying to connect to `http://127.0.0.1:5000/myHub`.
* If the connection uses the ID and takes too long to send a request to the server after the negotiate, the server:
* Deletes the ID.
* Returns a 404.
### Response code 400 or 503
For the following error:
```log
WebSocket connection to 'wss://xxx/HubName' failed: Error during WebSocket handshake: Unexpected response code: 400
Error: Failed to start the connection: Error: There was an error with the transport.
```
This error is usually caused by a client using only the WebSockets transport but the WebSocket protocol isn't enabled on the server.
### Response code 307
When using WebSockets and `skipNegotiation = true`
```log
WebSocket connection to 'ws://xxx/HubName' failed: Error during WebSocket handshake: Unexpected response code: 307
```
This error can also happen during the negotiate request.
Common cause:
* App is configured to enforce HTTPS by calling `UseHttpsRedirection` in `Startup`, or enforces HTTPS via URL rewrite rule.
Possible solution:
* Change the URL on the client side from "http" to "https". `.withUrl("https://xxx/HubName")`
### Response code 405
Http status code 405 - Method Not Allowed
* The app doesn't have [CORS](xref:signalr/security#cross-origin-resource-sharing) enabled
### Response code 0
Http status code 0 - Usually a [CORS](xref:signalr/security#cross-origin-resource-sharing) issue, no status code is given
```log
Cross-Origin Request Blocked: The Same Origin Policy disallows reading the remote resource at http://localhost:5000/default/negotiate?negotiateVersion=1. (Reason: CORS header 'Access-Control-Allow-Origin' missing).
```
* Add the expected origins to `.WithOrigins(...)`
```log
Cross-Origin Request Blocked: The Same Origin Policy disallows reading the remote resource at http://localhost:5000/default/negotiate?negotiateVersion=1. (Reason: expected 'true' in CORS header 'Access-Control-Allow-Credentials').
```
* Add `.AllowCredentials()` to your CORS policy. Cannot use `.AllowAnyOrigin()` or `.WithOrigins("*")` with this option
### Response code 413
Http status code 413 - Payload Too Large
This is often caused by having an access token that is over 4k.
* If using the Azure SignalR Service, reduce the token size by customizing the claims being sent through the Service with:
```csharp
.AddAzureSignalR(options =>
{
options.ClaimsProvider = context => context.User.Claims;
});
```
### Transient network failures
Transient network failures may close the SignalR connection. The server may interpret the closed connection as a graceful client disconnect. To get more info on why a client disconnected in those cases [gather logs from the client and server](xref:signalr/diagnostics).