С Новым годом! Форум программистов, компьютерный форум, киберфорум
C# для начинающих
Войти
Регистрация
Восстановить пароль
Карта форума Темы раздела Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.82/11: Рейтинг темы: голосов - 11, средняя оценка - 4.82
0 / 0 / 0
Регистрация: 04.10.2016
Сообщений: 11
1

Проверка имен из черного списка

08.10.2016, 23:02. Показов 2308. Ответов 19
Метки нет (Все метки)

Author24 — интернет-сервис помощи студентам
Добрый день, такая задачка, есть файл в котором записано некоторое количество имен типа qwe.1ew1.ru(черный список) необходимо написать программу на C# которая будет сравнивать имя(введенное пользователем например) с этим списком и если имя входит в него или является частью одного из имен то об этом как то сообщалось.
Если плохо объясняю, покажу конкретный пример:
имя из черного списка: a.b.c.ru;
b.c.ru - отправляется в бан(просто выводится сообщение)
qwe.a.b.c.ru - бан;
a.c.ru - спокойно проходит контроль.
надеюсь нормально сформулировал.

Добавлено через 7 минут
Вопрос собственно не в том как считывать с файла или еще что то. Меня интересует механизм проверки черного списка, хотя бы идею исполнение за мной.
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
08.10.2016, 23:02
Ответы с готовыми решениями:

Реализация черного списка пользователей через файловую БД
Есть самописная программка-БД с пользователями. Просто никак не врубаюсь, как реализовать можно...

Как убрать из черного списка сайт в антивирусе DR.Web
раньше сайт форум с музыкой хорошо открывался,а сейчас не как не могу зайти,антивирусник блочит...

Изменение/Просмотр черного списка MAC адрессов роутера через telnet (asus rt-n12vp)
Доброго дня, делаю программу которая будет администрировать мой роутер, баня на время MAC адреса...

Как отправить POST запрос на роутер для включения/отключения черного списка по mac адресам
С помощью Charles посмотрел, что за запрос отправляется при нажатии на кнопку "Применить"....

19
46 / 38 / 26
Регистрация: 11.08.2016
Сообщений: 139
09.10.2016, 12:04 2
Contains, не?
0
.NET C#,ASP.NET MVC
Эксперт .NET
594 / 507 / 224
Регистрация: 16.10.2010
Сообщений: 1,902
09.10.2016, 12:29 3
C#
1
2
3
4
var banList = new List<string> {"a.b.c.ru", "somestring"};
var keyWord = "b.c.ru";
if (banList.Contains(keyWord))
    //deny
0
46 / 38 / 26
Регистрация: 11.08.2016
Сообщений: 139
09.10.2016, 12:34 4
скорее так
C#
1
2
3
4
5
var banList = new List<string> {"a.b.c.ru", "somestring"};
var keyWord = "b.c.ru";
foreach (string s in banList)
if (s.Contains(keyWord))
    //deny
1
.NET C#,ASP.NET MVC
Эксперт .NET
594 / 507 / 224
Регистрация: 16.10.2010
Сообщений: 1,902
09.10.2016, 12:36 5
crackos, да спасибо что поправил, я что-то в облаках летал когда писал
1
0 / 0 / 0
Регистрация: 04.10.2016
Сообщений: 11
09.10.2016, 20:42  [ТС] 6
Спасибо, буду пробовать.

Добавлено через 15 минут
Еще такой вопрос, есть идеи как ускорить процесс, если не вариант просто зациклить и сравнивать 1000 раз
0
.NET C#,ASP.NET MVC
Эксперт .NET
594 / 507 / 224
Регистрация: 16.10.2010
Сообщений: 1,902
09.10.2016, 20:46 7
Цитата Сообщение от DoctorInTardis Посмотреть сообщение
Еще такой вопрос, есть идеи как ускорить процесс, если не вариант просто зациклить и сравнивать 1000 раз
Ускорить сравнение по списку? Если записей очень много, мб распаралелить цикл
1
0 / 0 / 0
Регистрация: 04.10.2016
Сообщений: 11
09.10.2016, 20:50  [ТС] 8
Нет, нужно именно алгоритм некий придумать.
0
.NET C#,ASP.NET MVC
Эксперт .NET
594 / 507 / 224
Регистрация: 16.10.2010
Сообщений: 1,902
09.10.2016, 20:54 9
DoctorInTardis, алгоритм чего? Сравнения на наличие подстроки в строке? Тоесть придумать велосипед?) Функция Contains() уже имеет этот алгоритм
1
0 / 0 / 0
Регистрация: 04.10.2016
Сообщений: 11
09.10.2016, 21:10  [ТС] 10
предположим что мне надо проверить 1000 имен, но 1000 раз прогонять их по списку не вариант, есть идеи?
0
.NET C#,ASP.NET MVC
Эксперт .NET
594 / 507 / 224
Регистрация: 16.10.2010
Сообщений: 1,902
09.10.2016, 21:13 11
Цитата Сообщение от DoctorInTardis Посмотреть сообщение
не вариант
вариант

я вам уже написал оду идею распаралелить цикл
1
601 / 485 / 185
Регистрация: 19.04.2016
Сообщений: 1,885
09.10.2016, 22:18 12
lvlkoo, DoctorInTardis,
C#
1
2
3
4
5
6
7
var l1 = new List<string>{ "Hello","World","List","Aray", "Woman", "Man"};
var l2 = new List<string>{ "Hello","Wold","Lst","Array", "Man"};
 
var result = l1.AsParallel().AsOrdered().Intersect(l2.AsParallel().AsOrdered());
 
Console.WriteLine(string.Join(" ", result));
Console.ReadKey(false);
1
0 / 0 / 0
Регистрация: 04.10.2016
Сообщений: 11
10.10.2016, 00:11  [ТС] 13
Сделал при помощи Contais + распараллелил, все здорово, за исключением одного. Таким образом можно найти только строгое совпадение имен, а мне необходимо несколько большее. А именно, если в черном списке(далее blacklist) есть имя скажем qw.ru то при проверке именя iu.qw.ru так же должно попадать выдавать результат как при совпадении.


P.S. Надеюсь я хоть немного понятно формулирую мысли.
0
.NET C#,ASP.NET MVC
Эксперт .NET
594 / 507 / 224
Регистрация: 16.10.2010
Сообщений: 1,902
10.10.2016, 00:16 14
C#
1
2
3
4
5
Parallel.ForEach(banList, (str) => 
    {
        if (str.Contains(keyWord))
             //deny
    }
0
0 / 0 / 0
Регистрация: 04.10.2016
Сообщений: 11
10.10.2016, 00:16  [ТС] 15
Все придумал, большое всем спасибо, не ожидал что так быстро будут отвечать).
0
Эксперт .NET
12568 / 8747 / 1311
Регистрация: 21.01.2016
Сообщений: 32,794
10.10.2016, 07:58 16
DoctorInTardis, в случае, если список такой большой (1000 записей), а имена должны строго совпадать, то нужно использовать хэш-таблицу Dictionary<>. Будет в сотни раз быстрее, чем тупой перебор всех записей в списке, даже без распараллеливания.

Добавлено через 6 минут
В данном случае, если нужно просто проверить наличие записи в каком-то множестве, то такая штука как HashSet вообще в кассу.
0
0 / 0 / 0
Регистрация: 06.02.2015
Сообщений: 15
12.09.2017, 10:29 17
DoctorInTardis, Подскажи пожалуйста, как в итоге решил задачу?
0
192 / 199 / 82
Регистрация: 11.04.2013
Сообщений: 1,086
12.09.2017, 10:37 18
Dazucad, не надо узнавать как он придумал, надо делать как правильно используй
Цитата Сообщение от Usaga Посмотреть сообщение
HashSet
0
0 / 0 / 0
Регистрация: 06.02.2015
Сообщений: 15
12.09.2017, 12:00 19
А что делать если имена не должны строго совпадать, и вводится не одно значение а сразу несколько(1000+)?
0
Эксперт .NET
12568 / 8747 / 1311
Регистрация: 21.01.2016
Сообщений: 32,794
12.09.2017, 12:25 20
Dazucad, если имена не строго совпадают, то можно использовать SortedSet<T> которому можно подсунуть свой IComparer<T> умеющий в нестрогое сравнение строк (нужно будет написать самому).

Количество записей роли вообще никакой не играет. Ищите по одной, в цикле, или раскидывайте между потоками (поиск по всем видам коллекций потокобезопасен).
1
12.09.2017, 12:25
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
12.09.2017, 12:25
Помогаю со студенческими работами здесь

Поиск файлов по маске из "чёрного" списка
Подскажите как вывести список файлов (и каталогов) с учетом масок &quot;черного&quot; списка Маски лежат в...

Проверка доменных имен.
Кто знает, есть ли место где можно проверить доменное имя сразу в нескольких зонах ( не...

Реализация "черного списка" пользователей
Имеется база данных freinds: id | author_id | freind_id | status. status: 1 - дружат, 0 - не...

Проверка совпадения имен файлов
Здравствуйте. Макросом из Ворда сохраняю файл в нужную папку на диске. При этом если файл с таким...


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

Или воспользуйтесь поиском по форуму:
20
Ответ Создать тему
Новые блоги и статьи
Как проводить научные вычисления на Python
InfoMaster 15.01.2025
Python стал одним из наиболее востребованных языков программирования в области научных вычислений благодаря своей простоте, гибкости и обширной экосистеме специализированных библиотек. Научные. . .
Создание игры типа Minecraft на PyGame/Python: пошаговое руководство
InfoMaster 15.01.2025
В данном руководстве мы рассмотрим процесс создания игры в стиле Minecraft с использованием библиотеки PyGame на языке программирования Python. Этот проект идеально подходит как для начинающих. . .
Как создать свою первую игру в стиле Doom на Unreal Engine
InfoMaster 15.01.2025
Разработка шутера от первого лица в стиле классического Doom представляет собой увлекательное путешествие в мир игрового программирования, где сочетаются творческий подход и технические навыки. . . .
Параллельное программировани­е: основные технологии и принципы
InfoMaster 15.01.2025
Введение в параллельное программирование Параллельное программирование представляет собой фундаментальный подход к разработке программного обеспечения, который позволяет одновременно выполнять. . .
Как написать микросервис на C# с Kafka, MediatR, Redis и GitLab CI/CD
InfoMaster 15.01.2025
В современной разработке программного обеспечения микросервисная архитектура стала стандартом де-факто для создания масштабируемых и гибких приложений. Этот подход позволяет разделить сложную систему. . .
Что такое CQRS и как это реализовать на C# с MediatR
InfoMaster 15.01.2025
Концепция CQRS и её роль в современной разработке В современном мире разработки программного обеспечения архитектурные паттерны играют ключевую роль в создании масштабируемых и поддерживаемых. . .
Как настроить CI/CD с Azure DevOps
InfoMaster 15.01.2025
CI/ CD, или непрерывная интеграция и непрерывное развертывание, представляет собой современный подход к разработке программного обеспечения, который позволяет автоматизировать и оптимизировать процесс. . .
Как настроить CI/CD с помощью Jenkins
InfoMaster 15.01.2025
Введение в CI/ CD и Jenkins В современной разработке программного обеспечения непрерывная интеграция (CI) и непрерывная доставка (CD) стали неотъемлемыми элементами процесса создания качественных. . .
Как написать микросервис на Go/Golang с Kafka, REST и GitHub CI/CD
InfoMaster 14.01.2025
Определение микросервиса, преимущества использования Go/ Golang Микросервис – это архитектурный подход к разработке программного обеспечения, при котором приложение состоит из небольших, независимо. . .
Как написать микросервис с нуля на C# с RabbitMQ, CQRS, Swagger и CI/CD
InfoMaster 14.01.2025
В современном мире разработки программного обеспечения микросервисная архитектура стала стандартом де-факто для создания масштабируемых и гибких приложений. Этот архитектурный подход предполагает. . .
Как создать интернет-магазин на PHP и JavaScript
InfoMaster 14.01.2025
В современном мире электронная коммерция стала неотъемлемой частью бизнеса. Создание собственного интернет-магазина открывает широкие возможности для предпринимателей, позволяя достичь большей. . .
Как написать Тетрис на Ассемблере
InfoMaster 14.01.2025
Тетрис – одна из самых узнаваемых и популярных компьютерных игр, созданная в 1984 году советским программистом Алексеем Пажитновым. За прошедшие десятилетия она завоевала симпатии миллионы людей по. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru