Форум программистов, компьютерный форум, киберфорум
C# .NET
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
0 / 0 / 0
Регистрация: 17.01.2013
Сообщений: 76

Выполнение пользовательской функции сервиса

09.03.2025, 16:36. Показов 1854. Ответов 9
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Всем привет
Вопрос к знатокам: в принципе возможно ли реализовать в службе windows пользовательскую функцию (в частности, нужна функция для выполнения запроса к БД и возврата полученных значений) и потом вызывать эту функцию из другого приложения по кнопке и получать готовые результаты запроса к БД?
Я сам в шоке, что пришлось рассматривать такой вариант, но других попросту нет
0
Лучшие ответы (1)
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
09.03.2025, 16:36
Ответы с готовыми решениями:

Создание пользовательской функции в MathCAD 11
Доброго форумчане и уни, пытаюсь написать простенькую функцию для mathcad 11 (более шустрая версия) почитав статью на хабре и примеры , ...

Создание пользовательской функции с параметрами
Как в c# windows forms создать функцию со своими параметрами, пробовал стандартным методом: public void myFunction(string...

Некоректная работа пользовательской функции
Приложение Windows Presentetion Foundation Есть код: matr = ""; UpdateListView(); и функция private void...

9
 Аватар для IamRain
4693 / 2701 / 734
Регистрация: 02.08.2011
Сообщений: 7,227
09.03.2025, 17:37
Цитата Сообщение от leshiy_t Посмотреть сообщение
службе windows
Работу, которую вы хотите переложить на windows service, обычно выполняет Web API, то есть веб-хост, который принимает запрос и отдает результат. Запросов нет? - сервис ничего не делает.
Да, Web API можно захостить (step-by-step гайд) как Windows Service.

Добавлено через 5 минут
Только шаблон подправить нужно, на деле вам не RazorPages (и WorkerService) нужен будет, а просто Controllers с маршрутами в описании пайплайна.

Добавлено через 15 минут
Вот еще пакет - Microsoft.Extensions.Hosting.WindowsServices. (правда пример кода оттуда не совсем актуален, но пакет сам по себе актуален).
Разбирайтесь.

Добавлено через 8 минут
Скорее всего, в идеале вам нужно именно Minimal API (если endpoint-ов мало) хостить как Windows Service.
Ссылки выше должны помочь.
0
Эксперт .NET
 Аватар для Wolfdp
3789 / 1766 / 371
Регистрация: 15.06.2012
Сообщений: 6,543
Записей в блоге: 3
09.03.2025, 22:35
Любой виндовый сервис -- обычная консольная программна без терминала (т.е. нет UI). Рассматривайте любое межпрограмное взаимодействие которое понравится. Web API хороший вариант, но обычно для програм берут gRPC.
0
Эксперт .NET
 Аватар для Usaga
14090 / 9308 / 1348
Регистрация: 21.01.2016
Сообщений: 34,956
11.03.2025, 15:22
Wolfdp, на самом деле не совсем обычное. Оно должно уметь обмениваться сигналами с менеджером служб (через апи специальный) иначе будет прибито как нерабочий сервис.
0
Эксперт .NET
 Аватар для Wolfdp
3789 / 1766 / 371
Регистрация: 15.06.2012
Сообщений: 6,543
Записей в блоге: 3
11.03.2025, 16:43
Usaga, Думаю даже если ТС сначала напишет полностью консольный вариант без единого понимания как собирать под сервис -- проблем перевода на сервис не будет и займет минимум времени. Особенно если возьмёт современный вариант web api, где всё стандартизировано и позволяет легко реализовать для обоих случаев, что резко упрощает разработку.
0
0 / 0 / 0
Регистрация: 17.01.2013
Сообщений: 76
11.03.2025, 23:07  [ТС]
Цитата Сообщение от Wolfdp Посмотреть сообщение
если ТС сначала напишет полностью консольный вариант
В этом то и заключается главная проблема - что стандартные решения не работают...
В общем, ситуация следующая:
Я пишу плагин для одной cad программы. Это плагин выбирает из БД необходимые данные, которые потом обрабатываются и отображаются в datagridview. В принципе, никаких сервисов, или дополнительных dll с выносом функция для работы с sql не требовалось - все работало из одной главной dll, которая и запускалась в этой cad программе. Проблема в том, что последние версии этой cad программы перевели на .net6, и этот переход оказался каким-то странным (не уверен, что буква "т" тут уместна) - любое взаимодействие с Microsoft.Data.SqlClient приводят к ошибке "Microsoft.Data.SqlClient is not supported on this platform" внутри этой cad программы. Я пробовал разные варианты - от выделения функций работы с БД в отдельную dll (пробовал .net6, core3.1, framework) до использования REST API и ODBC - результат один - ошибка, что это все не поддерживается в текущей платформе cad программы. Я не знаю, как именно происходит выполнение этих функций и команд, я не на столько грамотный программист, но у меня остался всего один вариант - вынести все функции для работы с БД в сервис, который должен (как я понимаю) выполняться на уровне операционной системы вне зависимости от того, кто вызывает эти функции, и возвращать уже готовый результат.

PS
попробовать web api смогу только в течение недели
0
Администратор
Эксперт .NET
 Аватар для OwenGlendower
18242 / 14156 / 5366
Регистрация: 17.03.2014
Сообщений: 28,846
Записей в блоге: 1
11.03.2025, 23:26
leshiy_t, пробовали поставить в файле проекта
XML
1
<TargetFramework>net6.0-windows</TargetFramework>
?
1
Эксперт .NET
 Аватар для Usaga
14090 / 9308 / 1348
Регистрация: 21.01.2016
Сообщений: 34,956
12.03.2025, 01:56
Лучший ответ Сообщение было отмечено leshiy_t как решение

Решение

leshiy_t, ну так с исходной проблемы и надо было начинать обсуждение...

Гугление показывает, что эту проблему люди ловят при разных условиях. Но не редко действительно звучит сценарий с плагином.

В данном обсуждении есть два поста с возможными решениями:

In my case, adding to .csproj file:

<!--see: [url]https://learn.microsoft.com/en-us/dotnet/core/project-sdk/msbuild-props#copylocallockfileassemblies[/url] -->
**<CopyLocalLockFileAssemblies>true</CopyLocalLockFileAssemblies>**
<!--<ProduceReferenceAssemblyInOutDir>true</ProduceReferenceAssemblyInOutDir>-->
<!--<SupportedOSPlatformVersion>7.0</SupportedOSPlatformVersion>-->
**<RuntimeIdentifier>win-x64</RuntimeIdentifier>**

managed to make it work.
(SQL, ODBC, ...)
In my case, I'm developing a DLL plugin for the AutoCAD software, the problem is that all Microsoft's tests / examples are for EXE applications and not for DLLs.
I also had this problem when upgrading from .NET 7.0 to .NET 8.0. Adding the nuget package
<PackageReference Include="Microsoft.Data.SqlClient" Version="5.2.0" />
To the executing application csproj fixed it. Why I don't know.
Звёздочками выделены добавленные строки. И две закомментированные\убранные.
1
0 / 0 / 0
Регистрация: 17.01.2013
Сообщений: 76
12.03.2025, 14:36  [ТС]
Цитата Сообщение от OwenGlendower Посмотреть сообщение
пробовали поставить в файле проекта
XMLСкопировано
1
<TargetFramework>net6.0-windows</TargetFramework>
Да - изначально было

Цитата Сообщение от Usaga Посмотреть сообщение
Звёздочками выделены добавленные строки
<CopyLocalLockFileAssemblies>true</CopyLocalLockFileAssemblies> - была изначально
<RuntimeIdentifier>win-x64</RuntimeIdentifier> - добавил и вроде это помогло, по крайней мере тестовая команда выполнилась и я получил нужный результат
Спасибо!!!
0
Эксперт .NET
 Аватар для Usaga
14090 / 9308 / 1348
Регистрация: 21.01.2016
Сообщений: 34,956
12.03.2025, 15:20
Цитата Сообщение от leshiy_t Посмотреть сообщение
добавил и вроде это помогло
Если я правильно понимаю, то это из-за сборки Microsoft.Sql.Client.SNI.dll, в которой находится реализация пространственных типов данных и которая является нативной, Windows only. Из-за неё и может быть мозгоклюйство, даже в случае, если пространственные типы данных ты не используешь.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
12.03.2025, 15:20
Помогаю со студенческими работами здесь

Ошибка в пользовательской функции, возвращающей TextBox1.Text
Вот такое вылезает, не могу понять, что за ошибка и как с ней бороться

Пользовательская функция: печать массива и сумма массива
Всем привет! Я язык вроде неплоха знаю, но вот с функциями беда, хотелось бы знать правильно ли я все сделал(пример работает, хотелось бы...

Windows-сервис не работает с пользовательским dBase driver(*.dbf)
Столкнулся с такой проблемой. Есть работающее вин-форм приложение, появилось желание реализовать в сервисе без gui. Ступор возник на...

RichTexBox.Text пользовательская функция!
Не изменяются данные в richTexBox.Text из пользовательской функций! Вообще то данные не меняются не только в richTexBox а во всех возможных...

Пользовательская функция, возвращающая сумму чисел, если переданные функции от А до В
Помогите пожалуйста, Составьте пользовательскую функцию, возвращающую сумму чисел, если переданные функции от А до В. Числа А и В...


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

Или воспользуйтесь поиском по форуму:
10
Ответ Создать тему
Новые блоги и статьи
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