Форум программистов, компьютерный форум, киберфорум
C# .NET
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.75/8: Рейтинг темы: голосов - 8, средняя оценка - 4.75
 Аватар для Lenoshka
39 / 39 / 3
Регистрация: 22.02.2013
Сообщений: 117
Записей в блоге: 2

CLR сборка и стороняя dll

18.11.2015, 13:04. Показов 1720. Ответов 1
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Добрый день!
Столкнулась с такой проблемой: у меня есть сборка, которая реализует пользовательскую функцию в БД. К этой сборке должна быть подключена библиотека стороннего разработчика. Если бы это была просто программка, то это можно было сделать через references, но в моем случае это невозможно и список доступных библиотек ограничен сборками, выложенными ранее на sql-сервере.
Пытаюсь подключить сборку cc.aa.dll, у которой namespace bb.aa таким образом:
1. Подкладываю библиотеку к проекту через "Добавить существующий объект"
2. прописываю using bb.aa;
3. пытаюсь подключить библиотеку
C#
1
 [DllImport("cc.аа.dll", CharSet = CharSet.Unicode)]
4. получаю ошибку "The type or namespase 'bb' could not be found (are you missing a using directive or an assembly reference?)"

Есть, конечно, вариант: выложить библиотеку на sql-сервер, тогда она появится в списке доступных для подключения, но админы меня скушают...
Должна же быть возможность подключать сторонние библиотеки прямо в CLR сборки?
Спасибо большое!
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
18.11.2015, 13:04
Ответы с готовыми решениями:

CLR сборка и ее вызов
Добрый день! Есть сборка (это ее часть) public static string fn_fk1_getdata(string xml, string url) { ......

Soap запрос и CLR сборка
Добрый день! Столкнулась с очень специфической проблемой: в sql запросе формируется сообщение для отправки в soap-запросе. В запросе...

Сборка Qt: отучение Qt от mingw10.dll, libgcc_s_dw2-1.dll и других Qt***.dll
В связи с тем, что часто возникают одни и те же вопросы, а в нете копаться никто не любит привожу перевод буржуйской вики по отлучению...

1
Эксперт .NETАвтор FAQ
 Аватар для Storm23
10427 / 5157 / 1825
Регистрация: 11.01.2015
Сообщений: 6,226
Записей в блоге: 34
18.11.2015, 15:36
Цитата Сообщение от Lenoshka Посмотреть сообщение
DllImport
DllImport делает просто вызов другой dll. Этот атрибут не внедряет внешнюю длл в вашу сборку. То есть что бы работал DllImport нужно наличие файла.

Что касается решения. Присоедените неуправялемую dll к проекту, в свойствах выставьте Embedded Resource. Таким образом, ваша длл будет физически храниться внутри сборки как ресурс.
Далее, при старте приложения, распакуйте вашу длл во временную папку (это Environment.GetFolderPath(Environment.Sp ecialFolder.ApplicationData) или Path.GetTempPath() - они должны быть доступны на запись даже со злыми админами), и используйте ее.
Код описан здесь http://stackoverflow.com/quest... -sharp-dll
Однако то решение, которое приведено на stackoverflow немного не годится для ImportDll, потому что ImportDll ищет длл в некой текущей директории, в которую запись может быть запрещена.
Поэтому, нужно указать виндовс искать длл в другой папке (в той, куда вы распаковали длл). Для этого оcпользуйте WInAPI функцию SetDllDirectory.
Подробнее зедсь http://stackoverflow.com/quest... at-runtime
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
18.11.2015, 15:36
Помогаю со студенческими работами здесь

Ошибка приложения. APPCRASH в clr.dll
На различных ОС работает нормально, на Windows Server 2008 R2 SP1 есть следующая проблема -> При запуске программы выдает ошибку: ...

Интеграция сторонней dll в MSSQL CLR
Добрый день, друзья! Хочу попросить помощи в данном вопросе Занимаюсь разработкой клиент-серверной программы в которой основная логика...

BEX clr.dll Код исключения: c0000409
Добрый день, У меня есть C#-приложение (VS2010, framework 4). На некоторых машинах при запуске получаю сообщение: Имя события...

fatal error C1190: managed targeted code requires '#using <mscorlib.dll>' and '/clr' option
fatal error C1190: managed targeted code requires '#using &lt;mscorlib.dll&gt;' and '/clr' option что делать???

Не работает стороняя библиотека Audiere в другом проекте
Всем доброго времени суток! Суть проблемы такая: - Скачал библиотеку Audiere для того, чтобы добавить саундтреки в игру -...


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

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Новые блоги и статьи
Программный контроль заполнения реквизита табличной части документа
Maks 02.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2. Задача: реализовать контроль заполнения реквизита "ПричинаСписания". . .
wmic не является внутренней или внешней командой
Maks 02.04.2026
Решение: DISM / Online / Add-Capability / CapabilityName:WMIC~~~~ Отсюда: https:/ / winitpro. ru/ index. php/ 2025/ 02/ 14/ komanda-wmic-ne-naydena/
Программная установка даты и запрет ее изменения
Maks 02.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2. Задача: при создании документов установить период списания автоматически. . .
Вывод данных в справочнике через динамический список
Maks 01.04.2026
Реализация из решения ниже выполнена на примере нетипового справочника "Спецтехника" разработанного в конфигурации КА2. Задача: вывести данные из ТЧ нетипового документа. . .
Программное заполнения текстового поля в реквизите формы документа
Maks 01.04.2026
Алгоритм из решения ниже реализован на нетиповом документе "ВыдачаОборудованияНаСпецтехнику" разработанного в конфигурации КА2, в дополнении к предыдущему решению. На форме документа создается. . .
К слову об оптимизации
kumehtar 01.04.2026
Вспоминаю начало 2000-х, университет, когда я писал на Delphi. Тогда среди программистов на форумах активно обсуждали аккуратную работу с памятью: нужно было следить за переменными, вовремя. . .
Идея фильтра интернета (сервер = слой+фильтр).
Hrethgir 31.03.2026
Суть идеи заключается в том, чтобы запустить свой сервер, о чём я если честно мечтал давно и давно приобрёл книгу как это сделать. Но не было причин его запускать. Очумелые учёные напечатали на. . .
Модель здравосоХранения 6. ESG-повестка и устойчивое развитие; углублённый анализ кадрового бренда
anaschu 31.03.2026
В прикрепленном документе раздумья о том, как можно поменять модель в будущем
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru