[FireDac][Phys][MySQL]-11011. Неподдерживаемая версия MySQL [0]. Firemonkey Delphi и Firedac
Здравствуйте, у меня возникла небольшая проблема. Я успешно создал форму для развертывания из DLL. Поэтому я сказал себе, почему бы не попробовать добавить подключение к базе данных в DLL. Я пошел и прочитал документацию по DLL http://docs.embarcadero.com/products/rad_studio/firedac/DLL_Development.html попробовал демо, и это сработало, поэтому я преобразовал демо в mysql, чтобы посмотреть, будет ли оно работать. Когда я пытаюсь вызвать Dll с основной формой приложения Project1.exe, он показал эту ошибку
[FireDac][Phys][MySQL]-11011. Неподдерживаемая версия MySQL [0]. Поддерживаются клиент и сервер с версии 3.20 до версии 6.2.
Но самое смешное, что я использую те же библиотеки, которые я использовал для подключения основного приложения к моему серверу MySQL, который использует те же компоненты. В основном приложение разделяет связь с формой DLL, в которой я думал, что теоретически это будет работать. Пожалуйста, помогите мне решить эту проблему, вот код ниже. Пожалуйста, скажите мне, если я делаю что-то не так.
Основное приложение - Project1.exe
unit ManageSystem;
interface
uses
System.Types, System.UITypes, System.Rtti, System.Classes,
System.Variants, FMX.Types, FMX.Controls, FMX.Forms, FMX.Dialogs,
FMX.StdCtrls, FMX.TabControl, FMX.Menus, FMX.Layouts, FMX.ListBox, FMX.Edit, SettingsFrm,
ChangePass, FMX.Objects, GroupsNPerm, AddUser,
{$IFDEF MSWINDOWS}
Winapi.Windows,
{$ENDIF}
System.SysUtils;
type
TShowDataProc = procedure (ACliHandle: Pointer); stdcall;
TManageF = class(TForm)
TabControl1: TTabControl;
TabItem1: TTabItem;
TabItem2: TTabItem;
StyleBook2: TStyleBook;
ListboxPopupMenu1: TPopupMenu;
MenuItem1: TMenuItem;
MenuItem2: TMenuItem;
MenuBar1: TMenuBar;
MenuItem3: TMenuItem;
MenuItem4: TMenuItem;
Panel1: TPanel;
AddUsreBtn: TButton;
GroupBox1: TGroupBox;
Label3: TLabel;
Label4: TLabel;
FirstNameEdit: TEdit;
Label5: TLabel;
LastNameEdit: TEdit;
Label6: TLabel;
EmailEdit: TEdit;
Label7: TLabel;
AddressEdit: TEdit;
Label8: TLabel;
TeleEdit: TEdit;
Label9: TLabel;
CellEdit: TEdit;
Label10: TLabel;
CommentEdit: TEdit;
EditBtn: TButton;
ChangePassBtn: TButton;
DeleteAcBtn: TButton;
SaveBtn: TButton;
CancelBtn: TButton;
UserNameEdit: TEdit;
GroupsBtn: TButton;
Label1: TLabel;
Label2: TLabel;
UserListBox: TListBox;
UserSearchEdit: TEdit;
SearchEditButton1: TSearchEditButton;
procedure GroupsBtnClick(Sender: TObject);
private
FhDll: THandle;
FpShowData: TShowDataProc;
{ Private declarations }
public
{ Public declarations }
end;
var
ManageF: TManageF;
implementation
{$R *.fmx}
uses
uADStanUtil;
procedure TManageF.GroupsBtnClick(Sender: TObject);
var
permissions : string;
begin
{$IFDEF WIN32}
{Permissions library to restrict access for unauthorized users}
permissions := 'permsec.dll';
{$ENDIF}
{$IFDEF WIN64}
permissions := 'permsec.dll';
{$ENDIF}
{$IFDEF MACOS}
{Permissions library to restrict access for unauthorized users}
permissions := '/usr/lib/libpermsec.dylib';
{$ENDIF}
FhDll := LoadLibrary(PChar(permissions));
if FhDll = 0 then
raise Exception.Create(ADLastSystemErrorMsg);
@FpShowData := GetProcAddress(FhDll, PChar('ShowGroupsNPerm'));
if not Assigned(FpShowData) then
raise Exception.Create(ADLastSystemErrorMsg);
FpShowData(SettingsF.ADConnection1.CliHandle);
end;
Библиотека DLL Project2.dll
library permsec;
{ Important note about DLL memory management: ShareMem must be the
first unit in your library's USES clause AND your project's (select
Project-View Source) USES clause if your DLL exports any procedures or
functions that pass strings as parameters or function results. This
applies to all strings passed to and from your DLL--even those that
are nested in records and classes. ShareMem is the interface unit to
the BORLNDMM.DLL shared memory manager, which must be deployed along
with your DLL. To avoid using BORLNDMM.DLL, pass string information
using PChar or ShortString parameters. }
uses
System.SysUtils,
System.Classes,
uADCompClient,
uADStanFactory,
GroupsNPerm in 'GroupsNPerm.pas' {GroupsF};
procedure ShowGroupsNPerm(ACliHandle: Pointer); stdcall;
begin
TGroupsF.ShowGroupsNPerm(ACliHandle);
end;
{$R *.res}
exports
ShowGroupsNPerm;
begin
end.
GroupsNPerm.pas это форма в dll
unit GroupsNPerm;
interface
uses
System.SysUtils, System.Types, System.UITypes, System.Rtti, System.Classes,
System.Variants, FMX.Types, FMX.Controls, FMX.Forms, FMX.Dialogs,
FMX.StdCtrls, FMX.Layouts, FMX.ListBox, FMX.TreeView, uADStanIntf,
uADStanOption, uADStanParam, uADStanError, uADDatSManager, uADPhysIntf,
uADDAptIntf, uADStanAsync, uADDAptManager, Data.DB, uADCompDataSet,
uADCompClient, uADGUIxIntf, uADPhysManager, uADPhysMySQL,
uADCompGUIx, uADGUIxFMXWait, uADStanDef, uADStanPool;
type
TGroupsF = class(TForm)
ToolBar1: TToolBar;
CreateGpBtn: TButton;
EditGrpBtn: TButton;
DeleGpBtn: TButton;
GrpListBox1: TListBox;
Panel1: TPanel;
TreeView1: TTreeView;
TreeViewItem1: TTreeViewItem;
TreeViewItem2: TTreeViewItem;
TreeViewItem3: TTreeViewItem;
TreeViewItem4: TTreeViewItem;
TreeViewItem5: TTreeViewItem;
TreeViewItem6: TTreeViewItem;
TreeViewItem7: TTreeViewItem;
TreeViewItem8: TTreeViewItem;
TreeViewItem9: TTreeViewItem;
TreeViewItem10: TTreeViewItem;
TreeViewItem11: TTreeViewItem;
ADQuery1: TADQuery;
ADPhysMySQLDriverLink1: TADPhysMySQLDriverLink;
ADGUIxWaitCursor1: TADGUIxWaitCursor;
ADPermConnect: TADConnection;
procedure GrpListBox1Click(Sender: TObject);
procedure FormCreate(Sender: TObject);
private
{ Private declarations }
public
{ Public declarations }
class procedure ShowGroupsNPerm(ACliHandle: Pointer);
end;
var
GroupsF: TGroupsF;
implementation
{$R *.fmx}
class procedure TGroupsF.ShowGroupsNPerm(ACliHandle: Pointer);
var
oForm: TGroupsF;
begin
oForm := TGroupsF.Create(nil);
oForm.ADPermConnect.SharedCliHandle := ACliHandle;
oForm.ADPermConnect.Connected := True;
oForm.ADQuery1.Close;
oForm.ADQuery1.SQL.Clear;
oForm.ADQuery1.SQL.Text := 'SELECT Group_Name FROM groups ORDER BY Group_Name';
try
oForm.ADQuery1.Open;
oForm.GrpListBox1.Items.Clear;
while not oForm.ADQuery1.Eof do
begin
oForm.GrpListBox1.Items.Add(oForm.ADQuery1.Fields[0].AsString);
oForm.ADQuery1.Next;
end;
finally
oForm.ADQuery1.Close;
end;
//oForm.ADQuery1.Active := True;
oForm.ShowModal;
oForm.Free;
end;
procedure TGroupsF.FormCreate(Sender: TObject);
begin
{$IFDEF WIN32}
ADPhysMySQLDriverLink1.VendorLib := ExtractFilePath(ParamStr(0)) + '/libmysqlx86.dll' ;
{$ENDIF}
{$IFDEF WIN64}
ADPhysMySQLDriverLink1.VendorLib := ExtractFilePath(ParamStr(0)) + '/libmysqlx64.dll' ;
{$ENDIF}
{$IFDEF MACOS}
ADPhysMySQLDriverLink1.VendorLib := '/usr/lib/libmysqlclient.dylib';
{$ENDIF}
end;
procedure TGroupsF.GrpListBox1Click(Sender: TObject);
begin
ADQuery1.Close;
ADQuery1.SQL.Clear;
ADQuery1.SQL.Text := 'SELECT * FROM groups WHERE Group_Name = :group';
ADQuery1.ParamByName('group').AsString := GrpListBox1.Items.Strings[GrpListBox1.ItemIndex];
ADQuery1.Open;
if ADQuery1.FieldByName('Access_Management_System').AsBoolean = TRUE then
TreeViewItem1.Ischecked := True
else
TreeViewItem1.Ischecked := False ;
if ADQuery1.FieldByName('Access_Pos').AsBoolean = TRUE then
TreeViewItem6.Ischecked := True
else
TreeViewItem6.Ischecked := False
end;
end.