gpt4 book ai didi

delphi - 我的程序如何检测它是否在特定域上运行?

转载 作者:行者123 更新时间:2023-12-03 15:13:22 25 4
gpt4 key购买 nike

我需要根据当前登录用户的位置限制应用程序的特定功能。由于我必须在 Delphi 中实现此逻辑,因此我不希望过度使用完整的 Active Directory/LDAP 查询。

我当前的想法是利用 DsGetDcName,并使用 DOMAIN_CONTROLLER_INFO 结构中返回的 GUID,并将其与硬编码常量进行比较。似乎有理由认为,只有重新创建域,域 GUID 才会更改,因此这将以有限的开销提供我想要的功能。我唯一担心的是我在 MSDN 上找不到任何文档来证实我的假设。

type
EAccessDenied = Exception;
EInvalidOwner = Exception;
EInsufficientBuffer = Exception;
ELibraryNotFound = Exception;

NET_API_STATUS = Integer;

TDomainControllerInfoA = record
DomainControllerName: LPSTR;
DomainControllerAddress: LPSTR;
DomainControllerAddressType: ULONG;
DomainGuid: TGUID;
DomainName: LPSTR;
DnsForestName: LPSTR;
Flags: ULONG;
DcSiteName: LPSTR;
ClientSiteName: LPSTR;
end;
PDomainControllerInfoA = ^TDomainControllerInfoA;

const
NERR_Success = 0;

procedure NetCheck(ErrCode: NET_API_STATUS);
begin
if ErrCode <> NERR_Success then
begin
case ErrCode of
ERROR_ACCESS_DENIED:
raise EAccessDenied.Create('Access is Denied');
ERROR_INVALID_OWNER:
raise EInvalidOwner.Create('Cannot assign the owner of this object.');
ERROR_INSUFFICIENT_BUFFER:
raise EInsufficientBuffer.Create('Buffer passed was too small');
else
raise Exception.Create('Error Code: ' + IntToStr(ErrCode) + #13 +
SysErrorMessage(ErrCode));
end;
end;
end;

function IsInternalDomain: Boolean;
var
NTNetDsGetDcName: function(ComputerName, DomainName: PChar; DomainGuid: PGUID; SiteName: PChar; Flags: ULONG; var DomainControllerInfo: PDomainControllerInfoA): NET_API_STATUS; stdcall;
NTNetApiBufferFree: function (lpBuffer: Pointer): NET_API_STATUS; stdcall;
LibHandle: THandle;
DomainControllerInfo: PDomainControllerInfoA;
ErrMode: Word;
const
NTlib = 'NETAPI32.DLL';
DS_IS_FLAT_NAME = $00010000;
DS_RETURN_DNS_NAME = $40000000;
INTERNAL_DOMAIN_GUID: TGUID = '{????????-????-????-????-????????????}';
begin
if Win32Platform = VER_PLATFORM_WIN32_NT then
begin
ErrMode := SetErrorMode(SEM_NOOPENFILEERRORBOX);
LibHandle := LoadLibrary(NTlib);
SetErrorMode(ErrMode);
if LibHandle = 0 then
raise ELibraryNotFound.Create('Unable to map library: ' + NTlib);
try
@NTNetDsGetDcName := GetProcAddress(Libhandle, 'DsGetDcNameA');
@NTNetApiBufferFree := GetProcAddress(Libhandle,'NetApiBufferFree');
try
NetCheck(NTNetDsGetDcName(nil, nil, nil, nil, DS_IS_FLAT_NAME or DS_RETURN_DNS_NAME, DomainControllerInfo));
Result := (DomainControllerInfo.DomainName = 'foo.com') and (CompareMem(@DomainControllerInfo.DomainGuid,@INTERNAL_DOMAIN_GUID, SizeOf(TGuid)));//WideCharToString(pDomain);
finally
NetCheck(NTNetApiBufferFree(DomainControllerInfo));
end;
finally
FreeLibrary(LibHandle);
end;
end
else
Result := False;
end;

ServerFault 上添加了相关问题按照建议。

Technet 上发现了另一篇有趣的读物这似乎也暗示我是对的,但并没有专门针对域 SID。

最佳答案

在域上创建服务帐户;

获取服务帐户的 GUID 并对其进行加密并将其保存在某个位置(注册表),可能作为企业安装过程的一部分来验证许可协议(protocol)。

启动客户端应用程序时,查询域服务帐户 GUID 并使用保存的 GUID 进行验证。

或者创建您自己的企业“ key ”服务器。

执行 LDAP 查询比执行所有域 Controller 的废话更容易。

关于delphi - 我的程序如何检测它是否在特定域上运行?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/4715512/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com