Я понимаю, что промежуточное ПО вводится между ними и окружено предыдущим то же самое. В ходе каждого мы можем вызвать вызов next()
и передать эстафету следующему, внутреннему продукту. По этой логике порядок может повлиять на поведение приложения. Однако я не вижу, как порядок может привести к разрыву цепочки (если только не произойдет исключение или разработчик не сможет вызвать next()
).
Я заметил, что следующий порядок (проект ванильной погоды) выполняет оба промежуточных программного обеспечения.
app.Use(async (context, next) => throw new Exception());
app.UseEndpoints(endpoints => endpoints.MapControllers());
Когда я переключаю порядок, как показано ниже, выполняется только UseEndPoints(...)
, в то время как Use(...)
никогда не происходит (согласно множеству точек останова, которые не сработали, и даже исключение не выдается).
app.UseEndpoints(endpoints => endpoints.MapControllers());
app.Use(async (context, next) => throw new Exception());
Я обнаружил, что некоторая информация, относящийся к веб-сокетам, говорит что-то об ошибке, если конвейер исчерпан. Однако это не приводит к указанной ошибке и на самом деле не вызывает веб-сокеты в моем ванильном проекте. Так что я чувствую, что упускаю что-то еще.
...you must keep the middleware pipeline running for the duration of the connection. If you attempt to send or receive a WebSocket message after the middleware pipeline ends, you may get an exception...
Причина указана в вашем вопросе: «разработчику не удается вызвать next()», хотя в данном случае это не ошибка как таковая, поскольку промежуточное ПО, по сути, является концом конвейера, если оно находит действие для выполнения.
См. источник.
С одной стороны, имеет смысл, что как только конечная точка распознана, передача эстафетной палочки прекращается. Тем не менее, мне кажется настолько интуитивно уместным, что «кольца ада» должны быть переданы на самый внутренний уровень, делая путешествие завершенным только тогда, когда нет другого уровня, который можно было бы вызвать. Или, по крайней мере, отмечайте такие мидлвары как
UseEndpointsAndPossiblyTerminate(...)
.