Труд вопреки насмешкам
 Аватар для Etyuhibosecyu
430 / 181 / 41
Регистрация: 13.07.2017
Сообщений: 4,771
Записей в блоге: 14
.NET 9

Регрессия: не удается запустить TcpListener - "Сделана попытка доступа к сокету методом, запрещенным правами доступа."

29.01.2025, 14:07. Показов 1980. Ответов 8
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
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
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
public partial class MainView : UserControl
{
    private enum ClientIndex
    {
        (XXX),
        (XXX),
        (XXX),
        (XXX),
    };
 
    private TcpListener tcpListener; //монитор подключений TCP клиентов
    private Thread listenThread; //создание потока
 
    private readonly List<TcpClient> clients = []; //список клиентских подключений
    private readonly List<NetworkStream> netStream = []; //список потока данных
    private readonly int port = (XXX);
#if RELEASE
    private readonly Random random = new();
#endif
 
    public MainView()
    {
        InitializeComponent();
        ...
#if RELEASE
        port = random.Next(1024, 65536);
#endif
    }
 
    private void UserControl_Loaded(object? sender, RoutedEventArgs e)
    {
        try
        {
            tcpListener = new(IPAddress.Loopback, port);
            listenThread = new(ListenThread) { Name = "Ожидание подключения клиентов", IsBackground = true };
            listenThread.Start(); //здесь вылетает с исключением из заголовка
            ...
        }
        catch
        {
            Disconnect();
        }
    }
 
    private void ListenThread()
    {
        tcpListener.Start();
        while (true)
        {
            clients.Add(tcpListener.AcceptTcpClient()); //подключение пользователя
            netStream.Add(clients[^1].GetStream()); //обьект для получения данных
            Thread clientThread = new(new ParameterizedThreadStart(ClientReceive)) { Name = "Соединение с клиентом #" + clients.Length.ToString() };
            clientThread.Start(clients.Length - 1);
            clientThread.IsBackground = true;
        }
    }
 
    private void ClientReceive(object? ID)
    {
        var client = (int?)ID ?? 0;
        byte[] receive;
        var receiveLen = GC.AllocateUninitializedArray<byte>(4);
        while (true)
        {
            try
            {
                netStream[client].ReadExactly(receiveLen);
                receive = GC.AllocateUninitializedArray<byte>(BitConverter.ToInt32(receiveLen));
                netStream[client].ReadExactly(receive);
                WorkUpReceiveMessage((ClientIndex)client, receive);
            }
            catch
            {
                clients.Clear();
                netStream.Clear();
                break;
            }
        }
    }
 
    private void Disconnect()
    {
        tcpListener.Stop(); //остановка чтения
        for (var i = 0; i < clients.Length; i++)
        {
            clients[i].Close(); //отключение клиента
            netStream[i].Close(); //отключение потока
        }
        Environment.Exit(0); //завершение процесса
    }
 
    private void SendMessageToClient(ClientIndex index, byte[] toSend)
    {
        var index2 = (int)index;
        var toSendLen = BitConverter.GetBytes(toSend.Length);
        netStream[index2].Write(toSendLen);
        netStream[index2].Flush(); //удаление данных из потока
        netStream[index2].Write(toSend);
        netStream[index2].Flush(); //удаление данных из потока
    }
 
    private async void WorkUpReceiveMessage(ClientIndex client, byte[] message)
    {
        try
        {
            if (message.Length == 0)
                return;
            ...
        }
        catch
        {
            ...
        }
    }
 
    private void SendUsedMethods()
    {
        if (netStream.Length < 4)
            try
            {
                ...
                return;
            }
            catch
            {
            }
        SendMessageToClient(ClientIndex.(XXX), ...);
        SendMessageToClient(ClientIndex.(XXX), ...);
        SendMessageToClient(ClientIndex.(XXX), ...);
        SendMessageToClient(ClientIndex.(XXX), ...);
    }
 
    private void SendUsedSizes()
    {
        if (netStream.Length < 3)
            try
            {
                ...
                return;
            }
            catch
            {
            }
        SendMessageToClient(ClientIndex.(XXX), ...);
        SendMessageToClient(ClientIndex.(XXX), ...);
    }
}
Как видите, код достаточно стандартный, обычный TCP-сервер с пользовательской обработкой сообщений. В .NET 9 вообще запретили TcpListener, или теперь его нужно запускать как-то иначе? Нейропоиск от Яндекса пока этого не знает, слишком узкая для него область. Надеюсь, люди смогут разбить эту проблему на несколько более широких и определить, какая именно проблема появилась в .NET 9 (потому что в .NET 8 все работало).
0
Лучшие ответы (1)
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
29.01.2025, 14:07
Ответы с готовыми решениями:

Сделана попытка доступа к сокету методом, запрещенным правами доступа
Пытаюсь написать простейший сниффер. Вылетает ошибка: Вот код сниффера: Помогите пжл:help:

Сделана попытка доступа к сокету методом, запрещенным правами доступа
Здравствуйте, возникла такая проблема. При запуске Web-сайта в PyCharm выдаёт ошибку. &quot;Сделана попытка доступа к сокету методом,...

Сделана попытка доступа к сокету методом, запрещенным правами доступа
Я писал в vs code. Через некоторое время бот перестал работать, а терминал пишет это: Traceback (most recent call last): File...

8
Эксперт .NET
 Аватар для Wolfdp
3790 / 1767 / 371
Регистрация: 15.06.2012
Сообщений: 6,543
Записей в блоге: 3
29.01.2025, 15:43

Не по теме:

Премудрая Хоро, какая красота....



Цитата Сообщение от Etyuhibosecyu Посмотреть сообщение
listenThread.Start(); //здесь вылетает с исключением из заголовка
100% не там, т.к. этот код стартует новый поток.

Выглядит как будто у вас настроем фаервол на блокировать все входящие подключения кроме избранных, без уведомления конечного пользователя. Рекомендую следующее:
- набрать минимальный набор на консоли, который будет тупо получать новое соединение и закидывать в общий спискок как у вас сейчас
- попереключаться на .net 8|9, чтобы убедиться есть ли проблема с конкретной версией.
0
Труд вопреки насмешкам
 Аватар для Etyuhibosecyu
430 / 181 / 41
Регистрация: 13.07.2017
Сообщений: 4,771
Записей в блоге: 14
29.01.2025, 15:48  [ТС]
Цитата Сообщение от Wolfdp Посмотреть сообщение
100% не там, т.к. этот код стартует новый поток.
Да, удалял в коде "чувствительную" информацию, решил пометить место вылета, увидел Start() и пометил. Как оказалось - не то. Вылетает строка tcpListener.Start(); (в листинге 47). Фаервол нормальный, ничего специально не трогал.

Добавлено через 1 минуту
Цитата Сообщение от Wolfdp Посмотреть сообщение
- попереключаться на .net 8|9
Не получится, так как в проекте куча библиотек, одна из которых (а может, и больше) уже использует фичи .NET 9.
0
Эксперт .NET
 Аватар для Wolfdp
3790 / 1767 / 371
Регистрация: 15.06.2012
Сообщений: 6,543
Записей в блоге: 3
29.01.2025, 16:27
Лучший ответ Сообщение было отмечено Etyuhibosecyu как решение

Решение

Цитата Сообщение от Etyuhibosecyu Посмотреть сообщение
Не получится, так как в проекте куча библиотек, одна из которых (а может, и больше) уже использует фичи .NET 9.
Блин, вы прикалываетесь? Или считаете что если запустить проект без ваших супер-дупер либ, то произойдет сбой матрицы?

C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
TcpListener tcpListener; //монитор подключений TCP клиентов
Thread listenThread; //создание потока
 
List<TcpClient> clients = []; //список клиентских подключений
List<NetworkStream> netStream = []; //список потока данных
 
            tcpListener = new(IPAddress.Loopback, port);
            listenThread = new(ListenThread) { Name = "Ожидание подключения клиентов", IsBackground = true };
            listenThread.Start(); //здесь вылетает с исключением из заголовка
 
Console.ReadKey();
 
void ListenThread()
    {
        tcpListener.Start();
        while (true)
        {
            clients.Add(tcpListener.AcceptTcpClient()); //подключение пользователя
            netStream.Add(clients[^1].GetStream()); //обьект для получения данных
Console.WriteLine("new connection");
        }
    }
Закиньте в новый консольный проект без всех ваших либ и проверте. Если также блочит -- файервол или ОСь. Если нет -- копайте что там наворотили в проекте.
1
Эксперт .NET
 Аватар для Usaga
14321 / 9411 / 1356
Регистрация: 21.01.2016
Сообщений: 35,474
29.01.2025, 16:36
Цитата Сообщение от Etyuhibosecyu Посмотреть сообщение
Регрессия
В этом функционале регрессии быть не может, ибо это очень широко используемая вещь. И тестами покрытая.

Без минимального проекта воспроизводящего проблему, единственное место, где может быть регрессия - твой код.
0
Труд вопреки насмешкам
 Аватар для Etyuhibosecyu
430 / 181 / 41
Регистрация: 13.07.2017
Сообщений: 4,771
Записей в блоге: 14
29.01.2025, 17:00  [ТС]
Цитата Сообщение от Wolfdp Посмотреть сообщение
Закиньте в новый консольный проект без всех ваших либ и проверте.
Проверил, точно так же вылетает. Значит, ОС. Перезагрузил компьютер, проблема исчезла. Тему можно не продолжать.
0
Эксперт .NET
 Аватар для Wolfdp
3790 / 1767 / 371
Регистрация: 15.06.2012
Сообщений: 6,543
Записей в блоге: 3
29.01.2025, 17:14
Цитата Сообщение от Etyuhibosecyu Посмотреть сообщение
Перезагрузил компьютер, проблема исчезла.
Цитата Сообщение от Etyuhibosecyu Посмотреть сообщение
C#
1
2
3
#if RELEASE
        port = random.Next(1024, 65536);
#endif
Возможно причина в этом, но это не точно (ошибка должна была бы быть другой).
0
Эксперт .NET
6691 / 4102 / 1607
Регистрация: 09.05.2015
Сообщений: 9,575
30.01.2025, 23:03
Эта ошибка скорее всего возникает из-за того, что порт(ы) находятся в зарезервированном виндой списке.

Посмотреть этот список можно командой
netsh interface ipv4 show excludedportrange protocol=tcp
0
Эксперт .NET
 Аватар для kolorotur
17823 / 12973 / 3382
Регистрация: 17.09.2011
Сообщений: 21,261
03.02.2025, 09:08
Etyuhibosecyu, 49152–65535 - эфемерные порты, их лучше не использовать для долгоживущей прослушки.
Ну и раз вы берете рандомный порт, то имеется вероятность выбрать тот, который уже используется другим процессом. Добавьте на этот случай проверку и повторный выбор порта.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
03.02.2025, 09:08
Помогаю со студенческими работами здесь

Сделана попытка доступа к сокету запрещенным правами доступа. Появилась после установки MS SQLExpress 2008
Собственно проблема. Есть приложение , серверная часть которого прослушивает соединения. До установки MS SQLExpress 2008 SP2 на...

Авторизация с правами доступа
Добрый день всем, нужна ваша помощь, нужно сделать авторизацию в windows form c# с права доступа (например для админа 1 форма, для юзера -...

Проблема с правами доступа.
Буду очень признателен, если кто-нибудь поможет мне с одной проблемой: Мне надо написать программу, использующую функции: :...

Непонятки с правами доступа
Может кто уже сталкивался с такой проблемой, тогда подскажите. В базе данных существуют объекты типа вьюшек, и таблиц под определенным...

Проблемы с правами доступа ...
Есть скрипт для создания папок на PHP скрипт лежит в var/www/ $cr_dir = mkdir( $dir_name , 0777 ); Это кусок от него .. в папке...


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

Или воспользуйтесь поиском по форуму:
9
Ответ Создать тему
Опции темы

Новые блоги и статьи
Отчёт о затраченных материалах за определенный период с макетом печатной формы
Maks 21.04.2026
Отчёт из решения ниже размещён в конфигурации КА2. Задача: показать затраченные материалы за определённый период, с возможностью вывода печатной формы отчёта с шапкой и подвалом. В качестве. . .
Отчёт о спецтехнике находящейся в ремонте
Maks 20.04.2026
Отчёт из решения ниже размещен в конфигурации КА2. Задача: отобразить спецтехнику, которая на данный момент находится в ремонте. Есть нетиповой документ "Заявка на ремонт спецтехники" который. . .
Памятка для бота и "визитка" для читателей "Semantic Universe Layer (Слой семантической вселенной)"
Hrethgir 19.04.2026
Сгенерировано для краткого описания по случаю сборки и компиляции скелета серверного приложения. И пусть после этого скажут, что статьи сгенерированные AI - туфта и не интересно. И это не реклама -. . .
Запрет удаления строк ТЧ документа при определённом условии
Maks 19.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "Аккумуляторы", разработанного в конфигурации КА2. У данного документа есть ТЧ, в которой в зависимости от прав доступа. . .
Модель заражения группы наркоманов
alhaos 17.04.2026
Условия задачи сформулированы тут Суть: - Группа наркоманов из 10 человек. - Только один инфицирован ВИЧ. - Колются одной иглой. - Колются раз в день. - Колются последовательно через. . .
Мысли в слух. Про "навсегда".
kumehtar 16.04.2026
Подумалось тут, что наверное очень глупо использовать во всяких своих установках понятие "навсегда". Это очень сильное понятие, и я только начинаю понимать край его смысла, не смотря на то что давно. . .
My Business CRM
MaGz GoLd 16.04.2026
Всем привет, недавно возникла потребность создать CRM, для личных нужд. Собственно программа предоставляет из себя базу данных клиентов, в которой можно фиксировать звонки, стадии сделки, а также. . .
Знаешь почему 90% людей редко бывают счастливыми?
kumehtar 14.04.2026
Потому что они ждут. Ждут выходных, ждут отпуска, ждут удачного момента. . . а удачный момент так и не приходит.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru