Форум программистов, компьютерный форум, киберфорум
Visual Basic .NET
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск  
 
 
Рейтинг 4.72/32: Рейтинг темы: голосов - 32, средняя оценка - 4.72
31 / 31 / 3
Регистрация: 08.08.2011
Сообщений: 195
.NET 4.x

Как из DLL на Delphi получить значения

15.06.2013, 01:20. Показов 7079. Ответов 50
Метки нет (Все метки)

Измучался! Понятно - не ас, хоть в VB.Net не первый день. Но уже двое суток бьюсь и никак!
Помогите:
Есть dll написанная в Delphi (с частями исходников), пытаюсь из неё получать информацию и получаю вечные - "PInvoke не возвращает Variable" или разнообразие типа того...
В общем вызываю функции а результат вечно никак...

Вот отрывок кода из Delphi:

Delphi
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
Library NativeDll;
 
uses
  SysUtils,
  Windows;
 
type
 
  PImageSet = ^TImageSet;
  TImageSet = packed record
    Size     : Word;
    FileName : Array[0..200] of Char;
  end;
 
  MsgSet = ^TMsgSet;
  TMsgSet = packed record
    Size     : Word;
    Msg      : Array[0..200] of Char;
  end;
 
function GetImage( Card: DWORD; Info: PImageSet ): Integer; stdcall; export;
begin
  Result := 1;
  if Card = 5 then begin
    Result := 0;
    Info^.FileName := 'BOOBLE.BMP';
  end;
end;
 
function GetMessage( Card: DWORD; Info: MsgSet ): Integer; stdcall; export;
begin
  Result := 1;
  if Card in [1..100] then begin
    Result := 0;
    Info^.Msg := 'Привет Васек!';
  end;
end;
 
exports
  GetMessage,
  GetImage;
 
begin
end.
Вызываю примерно так:

VB.NET
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
Imports System
Imports System.Text
Imports System.Runtime.InteropServices
 
Public Class NativeDelphi
 
    Public Structure PImageSet
        Dim Size As Int16
        Dim FFile() As Char ' пробовал всякое
    End Structure
 
    Public Structure MsgSet
        Dim Size As Int16
        Dim Foto() As Char ' пробовал всякое
    End Structure
 
    <DllImport("NativeDll.dll", EntryPoint:="GetImage", _
        CallingConvention:=CallingConvention.StdCall)> _
    Public Shared Function GetImage(ByRef Results As PImageSet) As Integer
    End Function
 
    ' и пробовал так
 
    <DllImport("NativeDll.dll", EntryPoint:="GetMessage", CharSet:=CharSet.Auto)> _
    Public Shared Function GetMessage(<MarshalAs(UnmanagedType.LPStr)> ByRef Result As MsgSet)
    End Function
 
End Class
Ошибки да и только. Уж вынес весь мозг. Перепробовал всякое. В инете толковых преобразований Delphi->VB.NET (особенно по поводу packed record и его понимания в VB.NEt, а задом чую - что собака там залежалась) не видать.
В общем если не решу - сопьюсь братцы... (и так литров 15 пива выпил в поиске да кучу сайтов (по сиг с каждого) покурил) Пожалейте здоровие мое!

PS: На счет маршалить - тут я честно говоря лох. Мож чего не так понимаю. Ясно одно - данные из дельфей приходят пакетом вполне упорядоченной структуры и размером, а как его жевать в VB.NET мне пока непонятно.
И есть еще один, для меня пока совсем непонятный тип - PChar (да не, про него я начитался вдоволь, просто непонятно - как его правильно принять из DLL Дельфей в VB.NET, учитывая, что он упакованный) В общем плиз HELP! Заранее ПАСИБО!
0
Лучшие ответы (1)
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
15.06.2013, 01:20
Ответы с готовыми решениями:

Получить данные через указатель из dll на delphi
Здравствуйте, помогите пожалуйста! имеется dll, написанная на delphi, где есть процедура: procedure GGetCell(Col : integer; Row :...

Как подключить dll, написанную на C, к dll на Delphi
Добрый день! Нужно подключить dll написанную на C к dll на Delphi. Как это можно сделать и можно ли вообще?

Есть исходник DLL на Delphi как (и возможно ли) написать похожее на VB.NET и использовать в среде программы написанной на Delphi
Суть вопроса вкратце такова - Есть исходник DLL написанной на Delphi Library Extdll; uses SysUtils, Windows; type ...

50
Почетный модератор
Эксперт .NET
 Аватар для NickoTin
8729 / 3681 / 404
Регистрация: 14.06.2010
Сообщений: 4,513
Записей в блоге: 9
01.07.2013, 20:02
Цитата Сообщение от RafStudio Посмотреть сообщение
как я понял, тут только методом проверки что вылезет
Нет, string - объект не изменяемый, в основном подается только на вход (как const string), StringBuilder же выступает в роли буфера, который может иметь какие-то данные при передаче в функцию, и одновременно может служить контейнером в который будут писать.

Я не знаю контекста функции, поэтому предполагаю. С большей долей вероятности будет именно string, но дабы не было дополнительных вопросов предложил возможный вариант.
1
31 / 31 / 3
Регистрация: 08.08.2011
Сообщений: 195
03.07.2013, 18:27  [ТС]
Оставил разбор получения картинки назначенной на счет на потом, в расчете разобраться. Но так и не вышло...
Потратил пару вечеров (правда конечно не только на данный вопрос, но все же)

Delphi
1
2
3
4
5
6
  type
  {процедура обратного вызова для записи информации, полученной от сервера}
  TFWrite = Procedure( Data: Pointer; Size: Integer ); stdcall;
 
  {получить назначенное на счёт изображение}
  Function GetAccountImage( Account: Integer; Proc: TFWrite ): BOOL; stdcall;
VB.NET
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
    ' Возврат назначенного на счет изображения
    <DllImport(CscLinkLib, EntryPoint:="GetAccountImage")> _
    Private Shared Function p_GetAccountImage(ByVal Account As Integer, ByVal callback As FWriteCallback) As Boolean
    End Function
 
    ' Процедура обратного вызова для записи информации, полученной от сервера
    Private Delegate Sub FWriteCallback(ByVal pData As IntPtr, ByVal size As Integer)
 
    ' Этот метод возвращает назначенное на счет изображение и будет вызван из CscLinkLib
    Private Shared Sub FWrite(<[In]()> ByVal pData As IntPtr, ByVal size As Integer)
    ' Здесь в pData и в size имеем некоторые значения. Но что с ними делать? По размеру, size не совпадает ни с размером загруженного
    ' изображения ни с количеством точек. pData - это вроде как представляет указатель или дескриптор... Бррр
    ' Признаюсь - не догоняю...
    ' И да - Вы предлагали тут маршаллить как Marshal.ReadX или Marshal.Copy
    ' Что то и с этим не очень выходит - опять натыкаюсь на разного рода ошибки
    End Sub
 
    ' Вызываем
    Dim callback As New FWriteCallback(AddressOf FWrite)
    p_GetAccountImage(Account, callback)
0
Почетный модератор
Эксперт .NET
 Аватар для NickoTin
8729 / 3681 / 404
Регистрация: 14.06.2010
Сообщений: 4,513
Записей в блоге: 9
03.07.2013, 19:21
Цитата Сообщение от RafStudio Посмотреть сообщение
pData - это вроде как представляет указатель или дескриптор
Указатель на адрес памяти.
Цитата Сообщение от RafStudio Посмотреть сообщение
Что то и с этим не очень выходит - опять натыкаюсь на разного рода ошибки
Как пытались?

Ничего конкретнее сказать не могу, нужна DLL и исходники идущие вместе с ней.
1
31 / 31 / 3
Регистрация: 08.08.2011
Сообщений: 195
03.07.2013, 20:13  [ТС]
Отправил все в личку.
Спасибо заранее!
0
31 / 31 / 3
Регистрация: 08.08.2011
Сообщений: 195
03.07.2013, 22:10  [ТС]
На всякий случай - загруженный файл jpg для аккаунта/счета 1

Название: 120px-Ben_Gunn2.jpg
Просмотров: 139

Размер: 4.9 Кб
0
31 / 31 / 3
Регистрация: 08.08.2011
Сообщений: 195
05.07.2013, 23:20  [ТС]
Просится подсказка:

Существует структура типа

VB.NET
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
    ' === ИНФОРМАЦИЯ О ТРАНЗАКЦИИ ===
    <StructLayout(LayoutKind.Sequential, CharSet:=CharSet.Ansi, Pack:=1)> _
    Public Structure TTransactionInfo
        ' Size of TTransactionInfo - заполнить перед вызовом
        Public Size As UShort
        ' 0-оплата 1-скидка 2-бонус 3-потраты гостя
        Public Kind As UShort
        ' Сумма в копейках
        Public Summa As Int64
        ' Код ресторана
        Public RestCode As UShort
        ' Дата чека (0 -> 30/12/1899)
        Public LogDate As Integer
        ' Номер кассы
        Public UnitNum As Byte
        ' Номер чека
        Public CheckNo As Integer
        ' Комментарий - для ручных транзакций
        <MarshalAs(UnmanagedType.ByValTStr, SizeConst:=256)> _
        Public Comment As String
    End Structure
Однако в контексте вызываемого метода к ней необходимо прикрутить еще два поля - Account типа Integer и TWhen типа Data
Именно прикрутить, поскольку необходимо вернуть массив TTransactionInfo содержащий в каждой записи информацию в этих двух полях...
Напрашивается сразу - добавь нужные типы данных в структуру и дело закрыто. Однако соль в том, что данная структура используется функцией ее и вызывающей. Соответственно изменение структуры приведет к изменению ее длины, ну а далее - попа.
Вот и вопрос - неужели придется создать вторую структуру с дополнительными полями только ради этой функции, или все же можно как-то ее реорганизовать скажем в копии с дополнительными типами данных...

Ну то есть:

VB.NET
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
    ' Процедура обратного вызова для перечисления транзакций по счету
    Private Delegate Sub EnumTransactionsCallback(<[In]()> ByVal Account As Integer, _
                                    ByVal TWhen As Date, ByRef info As TTransactionInfo)
 
    ' Перечислениe транзакций по счёту, результаты возвращаются через процедуру EnumTransactions
    <DllImport(CscLinkLib, CharSet:=CharSet.Ansi, EntryPoint:="GetAccountTransactions")> _
    Private Shared Function p_GetAccountTransactions(ByVal Account As Integer, ByVal DateFirst As Date, _
                                    ByVal DateLast As Date, ByVal callback As EnumTransactionsCallback) As Boolean
    End Function
 
    ' === МЕТОД ВОЗВРАЩАЕТ МАССИВ ТРАНЗАКЦИЙ ПО СЧЕУ И БУДЕТ ВЫЗВАН ИЗ EnumTransactionsCallback ===
    Private Shared Sub EnumTransactions(<[In]()> ByVal Account As Integer, _
                                    ByVal TWhen As Date, ByRef info As TTransactionInfo)
        'p_ListTransaction.Add(info) - добавит info в массив, однако туда же необходимо поместить еще Account и TWhen
    End Sub
Добавлено через 4 часа 21 минуту
Ясно - относительно контекста DLL Delphi - offtop.
Вопрос следовало задавать не в этом топике...
0
31 / 31 / 3
Регистрация: 08.08.2011
Сообщений: 195
06.07.2013, 15:21  [ТС]
Как и обещал - выкладываю класс для работы с внешней библиотекой написанной на Delphi

clsCscLink.rar

Класс написан в VS2010 на VB.NET
В данное время не работает функция возвращающая изображение назначенное на счет (GetAccountImage).
Любые замечания и предложения только приветствуются и радуют!

Для тех, кто в теме:
Класс clsCscLink предназначен для работы с csclink.dll версии 1.25 от компании UCS
Версии ниже не рассматривались и при желании Вы сможете сами адаптировать класс для работы с такими dll
Работоспособность проверена в системе x86 и при тестировании ошибок не замечено.
В системах x64 выдает ошибку, но у меня на данный момент не стояла задача решить данную проблему.
При желании, данный класс легко переделать во внешнюю компоненту для 1С (ну типа как у человека http://infostart.ru/public/60748/) да собственно и для множества других целей.

Для тех, кто не в курсе о чем речь:
Класс позволяет использовать csclink.dll которая предназначена для получения информации и ограниченного ее изменения в Персональной Дисконтной Системе (PDS) от компании UCS и используется главным образом в системе R-Keeper для обработки информации при использовании выданных гостям персональных карт на кассовых терминалах (система лояльности клиентов). Данная библиотека позволяет ограниченно изменять информацию о существующих клиентах и проводить разного рода кассовые транзакции, включая пополнение и изъятие денег со счета клиента.

О использовании:
Поскольку реализация идеи без помощи cyberforum.ru и, в частности, при огромном участии NickoTin была бы невозможна - данный класс выложен для использования в свободном виде. Однако указание ссылки, при использовании данного класса, на форум https://www.cyberforum.ru/, NickoTin и в частности RafStudio считаю уместным и правильным.

Пример использования:

CardInfo.rar

Следует учитывать - это просто пример!

В любом случае - данный клас поможет и послужит примером для других пользователей при обращении к нативным dll (в частности написанных в среде Delphi) из VB.NET
Желаю всем успехов в реализации идей!
1
31 / 31 / 3
Регистрация: 08.08.2011
Сообщений: 195
24.01.2017, 19:28  [ТС]
Лучший ответ Сообщение было отмечено NickoTin как решение

Решение

Прошло несколько лет и вот ко мне обратились с просьбой завершить начатое. Подумал, что дело хорошее и нужное, а потому согласился. В конце концов проект обретёт некую законченность. При этом поставили мне, так сказать, несколько условий, что-то типа технического задания, а в частности:

1 - написанный класс должен уметь использовать не только ту CscLink.dll что лежит в папке с ним, но и в принципе из любой указанной директории.

2 - класс должен работать как в x86 так и в x64 системах.

3 - когда в конце концов будет реализовано получение изображения назначенного на счёт?

В общем вопросы понятны и суть их я внял...
Не буду рассказывать как и почему именно так я решил поступить в реализации поставленных задач, главное в другом - всё получилось и ТЗ выполнено! Поэтому удовлетворённо ставлю для полученной версии релиз номер 1.0.0.0 Единственная тонкость: решение я выделил в DLL, поскольку так (как мне кажется) будет гораздо удобнее её использовать. И ещё - данная сборка предназначена для работы только с CscLink.dll от UCS версии 1.27 Именно в ней есть функция возвращающая изображение в неупакованном формате (GetAccountImageE), которая возвращает его в формате bmp. При использовании, следует знать, что библиотеки RTcp.dll следует ложить в папку с CscLinkNET.DLL, если их несколько - переименовывать и соответствующим образом прописывать в csclink.ini
Для тех же, кто только начинает попытки использования dll Delphi в своих программах на NET, выкладываю оригинальный CscLink.dll v1.27 вместе с исходником CscInt.pas, библиотеку связи с CardServ RTcp.dll, готовую для использования CscLinkNET.dll и, собственно, проект CscLinkNET, написанный в Visual Studio 2015. Сравнив его с CscInt.pas можно получить представление о том, как происходит обращение к процедурам и функциям исходной Delphi библиотеки.
Ещё раз выражаю огромную благодарность форуму cyberforum.ru и первому направляющему проекта, господину NickoTin!

PS: Маленькие особенности:
1 - при любой ошибке CscLinkNET.DLL генерирует исключение. Если кому-то это излишне - можете изменять поведение в исходнике так, как считаете нужным. Например вместо ошибки возвращать значение Boolean.

2 - целевым процессором выставлен x86. Не пытайтесь изменять - ничего хорошего не выйдет. В любом случае с такими настройками компилятора сборка отлично работает и в x86 и x64 системах без ошибок. ПРОВЕРЕННО! И вообще у меня закралось сомнение по поводу UCS но это другая история...

3 - Использовался DotNET 4.6.1 Наверняка версию можно понизить, однако этим не занимался и не пробовал. Дело в том, что конечный вариант работает на Windows Server 2012 R2 и MS SQL Server 2016 в купе с моим приложением, которое синхронизирует транзакции с абсолютно разных CardServ и работает отлично, без всяких дополнительных установок компонентов. В общем пробуйте, если надо, понижать Framework сами. Расскажете, насколько возможно понизить - буду рад!

На этом всё и конечно же ВСЕМ УДАЧИ!
Как выяснилось - годы работы решают!
Вложения
Тип файла: zip CscLink_v127.zip (64.6 Кб, 7 просмотров)
Тип файла: zip Rtcp.zip (62.8 Кб, 7 просмотров)
Тип файла: zip CscLinkNET_DLL.zip (9.7 Кб, 11 просмотров)
Тип файла: zip CscLinkNET_VS2015.zip (19.3 Кб, 11 просмотров)
3
548 / 355 / 120
Регистрация: 17.08.2014
Сообщений: 1,351
27.02.2017, 10:49
RafStudio, Добрый день, я делал библиотеку похожу для c# на Net4.0, скажите почему в последней версии вы перешли в динамическую загрузку библиотеки, а не стали использовать dllimport? не потому что используется константа?
0
31 / 31 / 3
Регистрация: 08.08.2011
Сообщений: 195
27.02.2017, 10:59  [ТС]
Необходимо было обеспечить возможность подключения нескольких csclink.dll работающих со своими rtcp.dll
Обновил до 1.1.5.0 - исправлены досадные ошибки....
Вложения
Тип файла: zip [CscLinkNET].zip (19.5 Кб, 12 просмотров)
0
31 / 31 / 3
Регистрация: 08.08.2011
Сообщений: 195
28.02.2017, 08:50  [ТС]
В этой версии снято ограничение по расположению rtcp.dll а так-же исправлена работа в случае использования в составе службы.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
28.02.2017, 08:50

Как средствами RTTI получить указатель на ComponentArray[0] или как получить значения некоторых свойств?
type TTestComponentItem = class(TComponent) end; TComponentArray = array of TTestComponentItem; TTestComponent =...

Как иcследовать DLL написанную на С++, Delphi?
Как иcследовать DLL написанную на С++, Delphi?

Как использовать в Delphi dll из .Net
Всем здравствуйте. Задача: разработать библиотечное приложение (работа с библиотечным сервером и субд oracle). Для работы с...

TableView Получить значения из ячеек в таблице, и присвоить эти значения переменным, а потом получить их сумму
есть код таблицы из примера с оф сайта docs.oracle как можно получить и присвоить переменной цифровое значение введенное в одну из...

Как получить HANDLE server.dll?(GetModuleHandle(L"server.dll") возвращает нули )
Мне необходимо получить HANDLE server.dll для ReadProcessMemory и WriteProcessMemory ,GetModuleHandle(L&quot;server.dll&quot;) возвращает нули...


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

Или воспользуйтесь поиском по форуму:
51
Ответ Создать тему
Новые блоги и статьи
Программа для com-порта
Uhbif79 05.06.2026
Всем привет, давно хотел изучить Qt, начинал, бросал, потом снова начинал. И сейчас вот смог написать свою первую программу. До этого имел опыт программирования микроконтроллеров, писал прошивки на. . .
Транскрипция 55-минутного видео через Whisper: WhisperDesktop облажался, спас Google Colab[
anaschu 01.06.2026
Понадобилось получить текст из свежезагруженного видео на YouTube. Казалось бы, задача на пять минут. Заняла полтора часа. Делюсь опытом — может кому пригодится последовательность решений. . . .
21 мат мед. Планы на развитие модели здравоСохранения
anaschu 01.06.2026
AnyLogic: план развития симуляционной модели рабочего коллектива — динамический абсентеизм, реальные данные, три сценария сравнения Продолжаю серию постов о дискретно-событийной модели рабочего. . .
20. Мат мед. Абсентеизм как отдельный тип простоя
anaschu 29.05.2026
Апдейт модели: исправленные баги, абсентеизм и новые механизмы Продолжаю развивать ранее описанную модель рабочего коллектива на AnyLogic. За последние несколько дней был проведён серьёзный. . .
19. здоровье, усталость и психотип работника влияют на производительность предприятия, и наоборот, производительность на здоровье, усталось и психотип
anaschu 28.05.2026
Дискретно-событийная модель рабочего коллектива на AnyLogic: здоровье, выгорание, психотипы и микростимуляция Привет, коллеги. Хочу поделиться итогами нескольких недель работы над симуляционной. . .
"Прокси" для последовательного порта
Eddy_Em 28.05.2026
Эту штуку написал я достаточно давно. Но сейчас вот понадобилось настроить датчик грозы, но при этом не отключать его от "метеодемона". Соответственно, надо запустить этот "прокси": метеодемон будет. . .
Рефакторинг программы уравнивания.
Massaraksh7 26.05.2026
Пример по предыдущей записи в блоге. Но, надо заметить, что, во-первых, там оптимизация не только математики, но и работы с базой данных, и с графами, а во-вторых, это ещё не всё.
Использование TThread в Lazarus для математических вычислений.
Massaraksh7 25.05.2026
Производя рефакторинг своих программ на предмет ускорения их работы, обратил внимание на такой аспект, как сокращение времени матвычислений. Дело в том, что приходится работать с большими матрицами. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru