Форум программистов, компьютерный форум, киберфорум
C#: Web, ASP.NET
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.80/5: Рейтинг темы: голосов - 5, средняя оценка - 4.80
 Аватар для Worldmaster
323 / 190 / 45
Регистрация: 25.08.2011
Сообщений: 1,263

Отловить исключения

28.12.2023, 18:23. Показов 1284. Ответов 15
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Здравствуйте.

в продолжение темы:

Сделал тут простенький вебсервер. на микротике есть правила для проброса 443 порта для SSL и 80 на порт сервера.
Но запросы из источника не доходят.
И при отправке запроса на сервак в консоли студии появляются записи типа:

Code
1
2
Вызвано исключение: "System.Security.Authentication.AuthenticationException" в System.Net.Security.dll
Вызвано исключение: "System.Security.Authentication.AuthenticationException" в System.Private.CoreLib.dll
Собсно вопрос. А как более подробно получить информацию об этом исключении??

Вроде бы написал свой мидлвар для логирования но он в данном случае даже не срабатывает.

C#
1
2
3
4
5
6
7
8
9
10
11
var builder = WebApplication.CreateBuilder(args);
 
builder.Logging.ClearProviders();
builder.Logging.AddConsole();
builder.Logging.AddDebug();
 
builder.Logging.AddFilter("Microsoft", LogLevel.Trace); // Категория Microsoft
builder.Logging.AddFilter("System", LogLevel.Trace); // Категория System
builder.Logging.AddFilter("WebApplication1", LogLevel.Trace); // Замените YourAppNamespace на пространство имен вашего приложения
 
builder.Services.AddScoped<IMessageWriter, LoggingMessageWriter>();
Даже вот так сделал но все равно не работает.

C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
app.Use(async (context, next) =>
{
    try
    {
        await next();
    }
    catch (Exception ex)
    {
        Console.WriteLine(ex.Message);
        // Логируйте информацию о некорректном запросе
        // или предпримите другие необходимые действия.
        // ex.RequestTelemetry содержит информацию о запросе.
        // ex.Message может содержать полезную информацию об ошибке.
        // ...
 
        context.Response.StatusCode = (int)HttpStatusCode.BadRequest;
        context.Response.ContentType = "text/plain";
        await context.Response.WriteAsync("Bad Request");
    }
});
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
28.12.2023, 18:23
Ответы с готовыми решениями:

Отловить событие
Всем привет! Задаю вопрос, который задают неоднократно, но ответы настолько абстрактные, что ты даже начинаешь сомневаться вообще в...

Организация собственного исключения и передача в него исходного исключения
Для обработки исключений при работе с БД я создал собственное исключение: public class SQLEntityException : ApplicationException ...

Отловить событие
Отловить событие, которое происходит при закрытии диспетчером задач моего процесса. Если такое вообще возможно сделать. Есть мысли на этот...

15
HF
 Аватар для HF
1303 / 882 / 199
Регистрация: 09.09.2011
Сообщений: 2,590
Записей в блоге: 2
28.12.2023, 19:19
Цитата Сообщение от Worldmaster Посмотреть сообщение
Сделал тут простенький вебсервер. на микротике есть правила для проброса 443 порта для SSL и 80 на порт сервера.
А запрос на 80 порт на прямую? Тоже ошибка? Или только после проброса?

Цитата Сообщение от Worldmaster Посмотреть сообщение
System.Security.Authentication.Authentic ationException
Такое исключение обычно возникает если авторизация/аутентификация активирована. Речи об этом не было.

Цитата Сообщение от Worldmaster Посмотреть сообщение
C#
1
var builder = WebApplication.CreateBuilder(args);
А всё остальное из Program.cs видимо вообще никак к делу не относится и на работу не влияет да? Мало ли что там наворочено.

Цитата Сообщение от Worldmaster Посмотреть сообщение
Даже вот так сделал но все равно не работает.
Уточнить бы всё же - это где сделано? В мидллваре или Program.cs, то где именно.
Чё б ему работать, если он до него не дошёл даже. Оно ж упало вроде на авторизации.

Наверное стоит включить UseDeveloperExceptionPage для режима разработки или HandlerException, чтобы ошибки в веб-результат падали.

Цитата Сообщение от Worldmaster Посмотреть сообщение
Сделал тут простенький вебсервер.
Видимо он далеко не простенький. Простенькие работают на простые запросы и не падают.
0
Эксперт .NET
 Аватар для Usaga
14087 / 9305 / 1348
Регистрация: 21.01.2016
Сообщений: 34,946
29.12.2023, 04:59
Цитата Сообщение от Worldmaster Посмотреть сообщение
Но запросы из источника не доходят.
И при отправке запроса на сервак в консоли студии появляются записи типа:
Так не доходят или реакция в консоли есть? Клиент, пославший запрос, что видит в итоге-то?
0
 Аватар для Worldmaster
323 / 190 / 45
Регистрация: 25.08.2011
Сообщений: 1,263
29.12.2023, 08:19  [ТС]
Цитата Сообщение от HF Посмотреть сообщение
А запрос на 80 порт на прямую? Тоже ошибка? Или только после проброса?
Если я с браузера запрашиваю то ответ прилетает как положено. Не работает только когда софтина шлет свой запрос и запрос через CURL.

Цитата Сообщение от HF Посмотреть сообщение
Такое исключение обычно возникает если авторизация/аутентификация активирована. Речи об этом не было.
И как ее обработать?


Цитата Сообщение от HF Посмотреть сообщение
А всё остальное из Program.cs видимо вообще никак к делу не относится и на работу не влияет да? Мало ли что там наворочено.

Да все из шаблона проекта МС.

C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
using System.Net;
using WebApplication1;
 
var builder = WebApplication.CreateBuilder(args);
builder.Logging.ClearProviders();
builder.Logging.AddConsole();
builder.Logging.AddDebug();
 
builder.Logging.AddFilter("Microsoft", LogLevel.Trace); // Категория Microsoft
builder.Logging.AddFilter("System", LogLevel.Trace); // Категория System
builder.Logging.AddFilter("WebApplication1", LogLevel.Trace); // Замените YourAppNamespace на пространство имен вашего приложения
 
builder.Services.AddScoped<IMessageWriter, LoggingMessageWriter>();
// Add services to the container.
 
builder.Services.AddControllers();
// Learn more about configuring Swagger/OpenAPI at https://aka.ms/aspnetcore/swashbuckle
builder.Services.AddEndpointsApiExplorer();
builder.Services.AddSwaggerGen();
 
var app = builder.Build();
 
// Configure the HTTP request pipeline.
if (app.Environment.IsDevelopment())
{
    app.UseSwagger();
    app.UseSwaggerUI();
}
 
// Обработка события OnBadRequest
app.Use(async (context, next) =>
{
    try
    {
        await next();
    }
    catch (Exception ex)
    {
        Console.WriteLine(ex.Message);
        // Логируйте информацию о некорректном запросе
        // или предпримите другие необходимые действия.
        // ex.RequestTelemetry содержит информацию о запросе.
        // ex.Message может содержать полезную информацию об ошибке.
        // ...
 
        context.Response.StatusCode = (int)HttpStatusCode.BadRequest;
        context.Response.ContentType = "text/plain";
        await context.Response.WriteAsync("Bad Request");
    }
});
app.UseHttpsRedirection();
 
app.UseAuthorization();
 
app.MapControllers();
 
app.Run();

Цитата Сообщение от HF Посмотреть сообщение
Уточнить бы всё же - это где сделано? В мидллваре или Program.cs, то где именно.
Вот эта штука LoggingMessageWriter в мидлвар.

Цитата Сообщение от HF Посмотреть сообщение
Видимо он далеко не простенький. Простенькие работают на простые запросы и не падают.
Так все работает если запрашивать из браузера. Но curl и основная софтина не хочет.


Цитата Сообщение от Usaga Посмотреть сообщение
Так не доходят или реакция в консоли есть? Клиент, пославший запрос, что видит в итоге-то?
Доходит видимо. Если браузер то все ок. Видим ответный JSON.
Если CURL то видимо егора. А основной софт ничего не показывает но при его запросе в консоли VS видим строку об исключении.
0
Эксперт .NET
 Аватар для Usaga
14087 / 9305 / 1348
Регистрация: 21.01.2016
Сообщений: 34,946
29.12.2023, 09:45
Цитата Сообщение от Worldmaster Посмотреть сообщение
Если CURL то видимо егора. А основной софт ничего не показывает но при его запросе в консоли VS видим строку об исключении.
Какие-то чудеса. Раз между браузером и курлом возникает разница, то значит и запросы разные ты посылаешь.

Что курл показывает?
0
HF
 Аватар для HF
1303 / 882 / 199
Регистрация: 09.09.2011
Сообщений: 2,590
Записей в блоге: 2
29.12.2023, 10:15
Цитата Сообщение от Worldmaster Посмотреть сообщение
if (app.Environment.IsDevelopment())
{
    app.UseSwagger();
    app.UseSwaggerUI();
}
Ну дак тут и добавляй. В шаблоне он же обычно вставляется.
Это страница с полным дампом ошибки.
C#
1
2
3
4
5
6
7
if (app.Environment.IsDevelopment())
{
    app.UseDeveloperExceptionPage();
 
    app.UseSwagger();
    app.UseSwaggerUI();
}[
Цитата Сообщение от Worldmaster Посмотреть сообщение
app.UseAuthorization();
А это что тогда?
Регистрации (ConfigureServices) не было, но Use сделал. Видимо это ошибка и значит.
И зачем она вообще, у тебя методы авторизацию что ли требуют?

C#
1
app.UseHttpsRedirection();
У тебя сайт на 80 порту всё-таки или на двух (80 + 443)?
А ты сам себя редиректишь на SSL если пришло на 80ый?
0
 Аватар для Worldmaster
323 / 190 / 45
Регистрация: 25.08.2011
Сообщений: 1,263
29.12.2023, 10:25  [ТС]
Цитата Сообщение от Usaga Посмотреть сообщение
Что курл показывает?
Bash
1
curl: (35) schannel: next InitializeSecurityContext failed: Unknown error (0x80092012) - Функция отзыва не смогла произвести проверку отзыва для сертификата.
Цитата Сообщение от HF Посмотреть сообщение
А это что тогда?
Регистрации (ConfigureServices) не было, но Use сделал. Видимо это ошибка и значит.
И зачем она вообще, у тебя методы авторизацию что ли требуют?

Это все шаблон созданный VS при создании проекта. Сайт при этом запускается. Маршрутизацию настроили. С браузера все показывает за исключением разве что ошибки сертификата.

Сертификат самоподписаный. И скорее всего именно из за него и возникает ошибка.
И софт поэтому не может пробиться.

Цитата Сообщение от HF Посмотреть сообщение
У тебя сайт на 80 порту всё-таки или на двух (80 + 443)?
А ты сам себя редиректишь на SSL если пришло на 80ый?
HTTPS у меня.
0
Эксперт .NET
 Аватар для Usaga
14087 / 9305 / 1348
Регистрация: 21.01.2016
Сообщений: 34,946
29.12.2023, 10:38
Цитата Сообщение от Worldmaster Посмотреть сообщение
curl: (35) schannel: next InitializeSecurityContext failed: Unknown error (0x80092012) - Функция отзыва не смогла произвести проверку отзыва для сертификата.
Так сертификат тухлый или самоподписной...
0
 Аватар для Worldmaster
323 / 190 / 45
Регистрация: 25.08.2011
Сообщений: 1,263
29.12.2023, 10:41  [ТС]
Цитата Сообщение от Usaga Посмотреть сообщение
Так сертификат тухлый или самоподписной...
для кого пишу то??

Цитата Сообщение от Worldmaster Посмотреть сообщение
Сертификат самоподписаный. И скорее всего именно из за него и возникает ошибка.
И софт поэтому не может пробиться.
Ясен пень что что то не так. Как исправить.

Как в анекдоте ей богу.
"Дядя, я знаю что у тебя сломалось"
0
Эксперт .NET
 Аватар для Usaga
14087 / 9305 / 1348
Регистрация: 21.01.2016
Сообщений: 34,946
29.12.2023, 10:59
Worldmaster, нормальный сертификат надо завести, конечно же) Можно ещё с машины, откуда запросы посылаются, в доверенное хранилище его добавить (пока самоподписной), чисто чтобы проверить, что всё работает.
0
 Аватар для Worldmaster
323 / 190 / 45
Регистрация: 25.08.2011
Сообщений: 1,263
29.12.2023, 11:22  [ТС]
Цитата Сообщение от Usaga Посмотреть сообщение
откуда запросы посылаются, в доверенное хранилище его добавить (пока самоподписной), чисто чтобы проверить, что всё работает.
Добавлен конечно.

Цитата Сообщение от Usaga Посмотреть сообщение
нормальный сертификат надо завести, конечно же)
Это если полноценный сервер с DNS именем. тут то его нет
0
 Аватар для IamRain
4693 / 2701 / 734
Регистрация: 02.08.2011
Сообщений: 7,227
29.12.2023, 11:31
Worldmaster, попробуйте попросить curl не проверять сертификаты.
0
 Аватар для Worldmaster
323 / 190 / 45
Регистрация: 25.08.2011
Сообщений: 1,263
29.12.2023, 13:00  [ТС]
Цитата Сообщение от IamRain Посмотреть сообщение
попробуйте попросить curl не проверять сертификаты.
курл то ладно. а как я программу попрошу.

В итоге плюнул на всю и пропатчил прогу и сменил ей адрес на мой внутренний http. И все заработало..

Но хотелось бы конечно без этого обойтись.
0
Эксперт .NET
 Аватар для Usaga
14087 / 9305 / 1348
Регистрация: 21.01.2016
Сообщений: 34,946
29.12.2023, 17:11
Цитата Сообщение от Worldmaster Посмотреть сообщение
Это если полноценный сервер с DNS именем. тут то его нет
А это не полноценный?
0
 Аватар для Worldmaster
323 / 190 / 45
Регистрация: 25.08.2011
Сообщений: 1,263
29.12.2023, 20:35  [ТС]
Usaga, блин.. ну нет. У меня обычный комп в локальной сети. Как можно сделать для него полноценный сертификат?
Ещё никто на это ответа не дал.

У меня есть сервис meshcentral и он тоже ругается что нет нормально сертификата. И нет возможности даже с помощью бесплатного ketsencrypt сделать полноценный сертификат для локальных адресов.

Если я не прав то покажите рабочий способ.
0
Эксперт .NET
 Аватар для Usaga
14087 / 9305 / 1348
Регистрация: 21.01.2016
Сообщений: 34,946
31.12.2023, 07:03
Worldmaster, для локального домена сертификаты не выдаются. Но если апшика не торчит в интернет, то тебе и HTTPS не нужен...

Добавлено через 15 минут
А так, ты можешь вытошнить ещё один сертификат и использовать его для подписывания самоподписного. И добавить его в локальное хранилище CA. Тогда на локальной машине все виды клиентов такой сертификат будут принимать как настоящий.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
31.12.2023, 07:03
Помогаю со студенческими работами здесь

Как отловить стандартные исключения
Здравствуйте. Я что-то не совсем понимаю, как реализовать следующее задание: Отловить пять любых стандартных типов исключений (например:...

С++, отловить исключение
Немного странный вопрос: Есть класс А, от него наследуется класс Б. В конструкторе класса А может генерироваться некое исключение. ...

Отловить из массива
Есть буфер char buf, другие типы буфера не подходят, известно, что в него будет подана 8-битная последовательность, как её отловить?...

Отловить прокси
Можно ли как-нибудь отловить прокси?

Отловить левый Ctrl
Как отловить нажатую клавишу CTRL левую? Вот так по пробовал не работает:( private void TxBx_KeyPress(object sender,...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
16
Ответ Создать тему
Новые блоги и статьи
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Access
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
Создание Single Page Application на фреймах
krapotkin 16.11.2025
Статья исключительно для начинающих. Подходы оригинальностью не блещут. В век Веб все очень привыкли к дизайну Single-Page-Application . Быстренько разберем подход "на фреймах". Мы делаем одну. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru