Access to XMLHttpRequest at 'serversiteurl//api/services/app/QklyProcessEngine/CallProcess' from origin 'clientsiteurl' has been blocked by CORS policy: No 'Access-Control-Allow-Origin' header is present on the requested resource.
Получаю эту ошибку выше, после вызова API от клиента и через 3 минуты я получаю ошибки каждый раз, когда я вызываю этот конкретный API. Я так смущен, что не могу сделать вывод, является ли это ошибкой API или ошибкой Cors.
ПРИМЕЧАНИЕ. Моя конфигурация Cors идеальна.
Каждый раз, когда у меня возникает проблема с Cors, я получаю следующую ошибку сервера.
System.Threading.Tasks.TaskCanceledException: A task was canceled.
at Microsoft.EntityFrameworkCore.Storage.RelationalTransaction.CreateSavepointAsync(String name, CancellationToken cancellationToken)
at Microsoft.EntityFrameworkCore.Storage.RelationalTransaction.CreateSavepointAsync(String name, CancellationToken cancellationToken)
at Microsoft.EntityFrameworkCore.Update.Internal.BatchExecutor.ExecuteAsync(IEnumerable`1 commandBatches, IRelationalConnection connection, CancellationToken cancellationToken)
at Microsoft.EntityFrameworkCore.Update.Internal.BatchExecutor.ExecuteAsync(IEnumerable`1 commandBatches, IRelationalConnection connection, CancellationToken cancellationToken)
at Microsoft.EntityFrameworkCore.Update.Internal.BatchExecutor.ExecuteAsync(IEnumerable`1 commandBatches, IRelationalConnection connection, CancellationToken cancellationToken)
at Microsoft.EntityFrameworkCore.ChangeTracking.Internal.StateManager.SaveChangesAsync(IList`1 entriesToSave, CancellationToken cancellationToken)
at Microsoft.EntityFrameworkCore.ChangeTracking.Internal.StateManager.SaveChangesAsync(StateManager stateManager, Boolean acceptAllChangesOnSuccess, CancellationToken cancellationToken)
at Microsoft.EntityFrameworkCore.SqlServer.Storage.Internal.SqlServerExecutionStrategy.ExecuteAsync[TState,TResult](TState state, Func`4 operation, Func`4 verifySucceeded, CancellationToken cancellationToken)
at Microsoft.EntityFrameworkCore.DbContext.SaveChangesAsync(Boolean acceptAllChangesOnSuccess, CancellationToken cancellationToken)
at Microsoft.EntityFrameworkCore.DbContext.SaveChangesAsync(Boolean acceptAllChangesOnSuccess, CancellationToken cancellationToken)
at Qkly.EntityFrameworkCore.QklyDbContext.SaveChangesAsync(Boolean acceptAllChangesOnSuccess, CancellationToken cancellationToken) in D:\a\Quickly-application\Quickly-application\src\Qkly.EntityFrameworkCore\EntityFrameworkCore\QklyDbContext.cs:line 6200
at Abp.EntityFramework...





Проверьте ответ сервера в консоли разработчика в своем браузере. Думаю, вы увидите код состояния 500 и страницу ServerError с вашего сервера.
И обычно эти страницы ошибок не содержат заголовков CORS или других подобных вещей.
Итак, у вас ошибка API сервера. Неспособность клиентского JS правильно прочитать эту ошибку (из-за CORS) является вторичной.
да, если только в вашем API не будет другой ошибки (включая CORS)
хорошо, если это ошибка сервера, то почему возникает проблема с политикой cors, из-за которой я не мог найти основную причину, и обе они не связаны между собой. При других ошибках сервера эта проблема с политикой Cors не возникает.
это ваш код, сложно провести полную диагностику только с одной трассировкой стека :)
Спасибо, это произошло из-за тайм-аута сервера. Я планировал увеличить тайм-аут сервера. Есть ли у вас какие-либо идеи?
Конечно. Перепишите свою БД и/или приложение, чтобы выполнение запроса не занимало много времени. Или вашим следующим шагом будет «обновление сервера» :)
ок, как долго HTTP-запрос ждет ответа?
спасибо, если я исправлю ошибку API, она будет исправлена?