Мне кажется, ASP. NET действительно возвращает код ошибки Bad Request (400), если он внутренне встречает какие-либо подозрительные символы в запросе. Например, когда ASP. NET пытается выбрать контроллер / действие на основе пути запроса, он вернет код ошибки 400, если путь содержит подозрительные символы.
Так что, когда ни один из моего кода даже выполнено, ASP. NET обрабатывает его правильно.
Код ошибки внутреннего сервера (500) возникает только тогда, когда мой код встречает подозрительные символы. Например, когда я пишу ...
var queryStringKeys = Request.QueryString.AllKeys.ToArray();
... свойство QueryString
там выдает HttpRequestValidationException
, если строка запроса содержит подозрительные символы. Если оставить это исключение необработанным, ASP. NET вернет ошибку 500 (как и любое другое необработанное исключение).
Таким образом, правильный способ справиться с этим - использовать оператор try / catch, а в перехватить блок, вернуть ответ на Bad Request самостоятельно. Я полагаю, вы также можете установить какой-то фильтр, который также обрабатывает HttpRequestValidationException
для вас в глобальном масштабе.