亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? sconnectex.pas

?? 一般的數據庫管理系統 uses Classes, SConnectEx, TltConst, ExtCtrls, MMSystem, Types, windows, TltLogic , Sy
?? PAS
?? 第 1 頁 / 共 5 頁
字號:
  hWinSock2: THandle;

{ Utility functions }

function LoadWinSock2: Boolean;
const
  DLLName = 'ws2_32.dll';
begin
  Result := hWinSock2 > 0;
  if Result then Exit;
  hWinSock2 := LoadLibrary(PChar(DLLName));
  Result := hWinSock2 > 0;
  if Result then
  begin
    WSACreateEvent := GetProcAddress(hWinSock2, 'WSACreateEvent');
    WSAResetEvent := GetProcAddress(hWinSock2, 'WSAResetEvent');
    WSACloseEvent := GetProcAddress(hWinSock2, 'WSACloseEvent');
    WSAEventSelect := GetProcAddress(hWinSock2, 'WSAEventSelect');
  end;
end;

procedure GetPacketInterceptorList(List: TStringList);
var
  EnumGUID: IEnumGUID;
  Fetched: Cardinal;
  Guid: TGUID;
  Rslt: HResult;
  CatInfo: ICatInformation;
  I: Integer;
  ClassIDKey: HKey;
  S: string;
  Buffer: array[0..255] of Char;
begin
  List.Clear;
  Rslt := CoCreateInstance(CLSID_StdComponentCategoryMgr, nil,
    CLSCTX_INPROC_SERVER, ICatInformation, CatInfo);
  if Succeeded(Rslt) then
  begin
    OleCheck(CatInfo.EnumClassesOfCategories(1, @CATID_MIDASInterceptor, 0, nil, EnumGUID));
    while EnumGUID.Next(1, Guid, Fetched) = S_OK do
      List.Add(ClassIDToProgID(Guid));
  end else
  begin
    if RegOpenKey(HKEY_CLASSES_ROOT, 'CLSID', ClassIDKey) <> 0 then
      try
        I := 0;
        while RegEnumKey(ClassIDKey, I, Buffer, SizeOf(Buffer)) = 0 do
        begin
          S := Format(SCatImplKey,[Buffer, GUIDToString(CATID_MIDASInterceptor)]);
          List.Add(ClassIDToProgID(StringToGUID(Buffer)));
          Inc(I);
        end;
      finally
        RegCloseKey(ClassIDKey);
      end;
  end;
end;

procedure FreeWinSock2;
begin
  if hWinSock2 > 0 then
  begin
    WSACreateEvent := nil;
    WSAResetEvent := nil;
    WSACloseEvent := nil;
    WSAEventSelect := nil;
    FreeLibrary(hWinSock2);
  end;
  hWinSock2 := 0;
end;

procedure GetDataBrokerList(List: TStringList; const RegCheck: string);

  function OpenRegKey(Key: HKey; const SubKey: string): HKey;
  begin
    if Windows.RegOpenKey(Key, PChar(SubKey), Result) <> 0 then Result := 0;
  end;

  function EnumRegKey(Key: HKey; Index: Integer; var Value: string): Boolean;
  var
    Buffer: array[0..255] of Char;
  begin
    Result := False;
    if Windows.RegEnumKey(Key, Index, Buffer, SizeOf(Buffer)) = 0 then
    begin
      Value := Buffer;
      Result := True;
    end;
  end;

  function QueryRegKey(Key: HKey; const SubKey: string;
    var Value: string): Boolean;
  var
    BufSize: Longint;
    Buffer: array[0..255] of Char;
  begin
    Result := False;
    BufSize := SizeOf(Buffer);
    if Windows.RegQueryValue(Key, PChar(SubKey), Buffer, BufSize) = 0 then
    begin
      Value := Buffer;
      Result := True;
    end;
  end;

  procedure CloseRegKey(Key: HKey);
  begin
    RegCloseKey(Key);
  end;

var
  I: Integer;
  ClassIDKey: HKey;
  ClassID, S: string;
begin
  List.Clear;
  ClassIDKey := OpenRegKey(HKEY_CLASSES_ROOT, 'CLSID');
  if ClassIDKey <> 0 then
    try
      I := 0;
      while EnumRegKey(ClassIDKey, I, ClassID) do
      begin
        if RegCheck <> '' then
        begin
          QueryRegKey(ClassIDKey, ClassID + '\' + RegCheck, S);
          if S <> SFlagOn then continue;
        end;
        if not QueryRegKey(ClassIDKey, ClassID + '\Control', S) and
           QueryRegKey(ClassIDKey, ClassID + '\ProgID', S) and
           QueryRegKey(ClassIDKey, ClassID + '\TypeLib', S) and
           QueryRegKey(ClassIDKey, ClassID + '\Version', S) and
           QueryRegKey(ClassIDKey, ClassID + '\Borland DataBroker', S) then
          List.Add(ClassIDToProgID(StringToGUID(ClassID)));
        Inc(I);
      end;
    finally
      CloseRegKey(ClassIDKey);
    end;
end;

{ TDataBlock }

constructor TDataBlock.Create;
begin
  inherited Create;
  FIgnoreStream := False;
  FStream := TMemoryStream.Create;
  Clear;
end;

destructor TDataBlock.Destroy;
begin
  if not FIgnoreStream then
    FStream.Free;
  inherited Destroy;
end;

{ TDataBlock.IDataBlock }

function TDataBlock.GetBytesReserved: Integer;
begin
  Result := SizeOf(Integer) * 2;
end;

function TDataBlock.GetMemory: Pointer;
var
  DataSize: Integer;
begin
  FStream.Position := 4;
  DataSize := FStream.Size - BytesReserved;
  FStream.Write(DataSize, SizeOf(DataSize));
  Result := FStream.Memory;
end;

function TDataBlock.GetSize: Integer;
begin
  Result := FStream.Size - BytesReserved;
end;

procedure TDataBlock.SetSize(Value: Integer);
begin
  FStream.Size := Value + BytesReserved;
end;

function TDataBlock.GetStream: TStream;
var
  DataSize: Integer;
begin
  FStream.Position := 4;
  DataSize := FStream.Size - BytesReserved;
  FStream.Write(DataSize, SizeOf(DataSize));
  FStream.Position := 0;
  Result := FStream;
end;

function TDataBlock.GetSignature: Integer;
begin
  FStream.Position := 0;
  FStream.Read(Result, SizeOf(Result));
end;

procedure TDataBlock.SetSignature(Value: Integer);
begin
  FStream.Position := 0;
  FStream.Write(Value, SizeOf(Value));
end;

procedure TDataBlock.Clear;
begin
  FStream.Size := BytesReserved;
  FReadPos := BytesReserved;
  FWritePos := BytesReserved;
end;

function TDataBlock.Write(const Buffer; Count: Integer): Integer;
begin
  FStream.Position := FWritePos;
  Result := FStream.Write(Buffer, Count);
  FWritePos := FStream.Position;
end;

function TDataBlock.Read(var Buffer; Count: Integer): Integer;
begin
  FStream.Position := FReadPos;
  Result := FStream.Read(Buffer, Count);
  FReadPos := FStream.Position;
end;

procedure TDataBlock.IgnoreStream;
begin
  FIgnoreStream := True;
end;

function TDataBlock.InitData(Data: Pointer; DataLen: Integer; CheckLen: Boolean): Integer; stdcall;
var
  Sig: Integer;
  P: Pointer;
begin
  P := Data;
  if DataLen < 8 then   //4位標識4位長度
    raise Exception.CreateRes(@SInvalidDataPacket);
  Sig := Integer(P^); //標識
  P := Pointer(Integer(Data) + SizeOf(Sig));
  if (Sig and CallSig <> CallSig) and //標識的8~15位固定
     (Sig and ResultSig <> ResultSig) then
    raise Exception.CreateRes(@SInvalidDataPacket);
  Signature := Sig;  //調用標識
  Result := Integer(P^); //返回值(數據長度)
  P := Pointer(Integer(P) + SizeOf(Result));
  if CheckLen then //檢測長度
  begin
    if (Result <> DataLen - 8) then
      raise Exception.CreateRes(@SInvalidDataPacket);
    Size := Result;
    if Result > 0 then  //如果存在數據,則發送。
      Write(P^, Result);
  end else
  begin
    Size := DataLen - 8;
    if Size > 0 then
      Write(P^, Size);
  end;
end;

{ TDataBlockInterpreter }

const

  EasyArrayTypes = [varSmallInt, varInteger, varSingle, varDouble, varCurrency,
                    varDate, varBoolean, varByte];

  VariantSize: array[0..varByte] of Word  = (0, 0, SizeOf(SmallInt), SizeOf(Integer),
    SizeOf(Single), SizeOf(Double), SizeOf(Currency), SizeOf(TDateTime), 0, 0,
    SizeOf(Integer), SizeOf(WordBool), 0, 0, 0, 0, 0, SizeOf(Byte));

constructor TDataBlockInterpreter.Create(SendDataBlock: ISendDataBlock; CheckRegValue: string);
begin
  inherited Create;
  FSendDataBlock := SendDataBlock;
  FDispatchList := TList.Create;
  FCheckRegValue := CheckRegValue;
end;

destructor TDataBlockInterpreter.Destroy;
var
  i: Integer;
begin
  for i := FDispatchList.Count - 1 downto 0 do
    TDataDispatch(FDispatchList[i]).FInterpreter := nil;
  FDispatchList.Free;
  FSendDataBlock := nil;
  inherited Destroy;
end;

procedure TDataBlockInterpreter.AddDispatch(Value: TDataDispatch);
begin
  if FDispatchList.IndexOf(Value) = -1 then
    FDispatchList.Add(Value);
end;

procedure TDataBlockInterpreter.RemoveDispatch(Value: TDataDispatch);
begin
  FDispatchList.Remove(Value);
end;

{ Variant conversion methods }

function TDataBlockInterpreter.GetVariantPointer(const Value: OleVariant): Pointer;
begin
  case VarType(Value) of
    varEmpty, varNull: Result := nil;
    varDispatch: Result := TVarData(Value).VDispatch;
    varVariant: Result := @Value;
    varUnknown: Result := TVarData(Value).VUnknown;
  else
    Result := @TVarData(Value).VPointer;
  end;
end;

procedure TDataBlockInterpreter.CopyDataByRef(const Source: TVarData; var Dest: TVarData);
var
  VType: Integer;
begin
  VType := Source.VType;
  if Source.VType and varArray = varArray then
  begin
    VarClear(OleVariant(Dest));
    SafeArrayCopy(PSafeArray(Source.VArray), PSafeArray(Dest.VArray));
  end else
    case Source.VType and varTypeMask of
      varEmpty, varNull: ;
      varOleStr:
      begin
        if (Dest.VType and varTypeMask) <> varOleStr then
          Dest.VOleStr := SysAllocString(Source.VOleStr) else
        if (Dest.VType and varByRef) = varByRef then
          SysReallocString(PBStr(Dest.VOleStr)^,Source.VOleStr) else
          SysReallocString(Dest.VOleStr,Source.VOleStr);
      end;
      varDispatch: Dest.VDispatch := Source.VDispatch;
      varVariant: CopyDataByRef(PVarData(Source.VPointer)^, Dest);
      varUnknown: Dest.VUnknown := Source.VUnknown;
    else
      if Dest.VType = 0 then
        OleVariant(Dest) := OleVariant(Source) else
      if Dest.VType and varByRef = varByRef then
      begin
        VType := VType or varByRef;
        Move(Source.VPointer, Dest.VPointer^, VariantSize[Source.VType and varTypeMask]);
      end else
        Move(Source.VPointer, Dest.VPointer, VariantSize[Source.VType and varTypeMask]);
    end;
  Dest.VType := VType;
end;

function TDataBlockInterpreter.ReadArray(VType: Integer;
  const Data: IDataBlock): OleVariant;
var
  Flags: TVarFlags;
  LoDim, HiDim, Indices, Bounds: PIntArray;
  DimCount, VSize, i: Integer;
  {P: Pointer;}
  V: OleVariant;
  LSafeArray: PSafeArray;
  P: Pointer;
begin
  VarClear(Result);
  Data.Read(DimCount, SizeOf(DimCount));
  VSize := DimCount * SizeOf(Integer);
  GetMem(LoDim, VSize);
  try
    GetMem(HiDim, VSize);
    try
      Data.Read(LoDim^, VSize);
      Data.Read(HiDim^, VSize);
      GetMem(Bounds, VSize * 2);
      try
        for i := 0 to DimCount - 1 do
        begin
          Bounds[i * 2] := LoDim[i];
          Bounds[i * 2 + 1] := HiDim[i];
        end;
        Result := VarArrayCreate(Slice(Bounds^,DimCount * 2), VType and varTypeMask);
      finally
        FreeMem(Bounds);
      end;
      if VType and varTypeMask in EasyArrayTypes then
      begin
        Data.Read(VSize, SizeOf(VSize));
        P := VarArrayLock(Result);
        try
          Data.Read(P^, VSize);
        finally
          VarArrayUnlock(Result);
        end;
      end else
      begin
        LSafeArray := PSafeArray(TVarData(Result).VArray);
        GetMem(Indices, VSize);
        try
          FillChar(Indices^, VSize, 0);
          for I := 0 to DimCount - 1 do
            Indices[I] := LoDim[I];
          while True do
          begin
            V := ReadVariant(Flags, Data);
            if VType and varTypeMask = varVariant then
              OleCheck(SafeArrayPutElement(LSafeArray, Indices^, V)) else
              OleCheck(SafeArrayPutElement(LSafeArray, Indices^, TVarData(V).VPointer^));
            Inc(Indices[DimCount - 1]);
            if Indices[DimCount - 1] > HiDim[DimCount - 1] then
              for i := DimCount - 1 downto 0 do
                if Indices[i] > HiDim[i] then
                begin
                  if i = 0 then Exit;
                  Inc(Indices[i - 1]);
                  Indices[i] := LoDim[i];
                end;
          end;
        finally
          FreeMem(Indices);
        end;
      end;
    finally
      FreeMem(HiDim);

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
久久电影网电视剧免费观看| 国内精品伊人久久久久av一坑| 日韩一区二区三区av| 成人的网站免费观看| 亚洲成av人片| 成人免费在线视频| 亚洲精品在线网站| 欧美日韩国产a| 91免费国产在线观看| 国产精品原创巨作av| 免费欧美在线视频| 亚洲一区二区欧美日韩| 成人欧美一区二区三区视频网页 | 一本色道亚洲精品aⅴ| 久久超碰97中文字幕| 亚洲一卡二卡三卡四卡五卡| 欧美国产禁国产网站cc| 久久久久久**毛片大全| 日韩欧美精品在线| 欧美日韩国产乱码电影| 色av成人天堂桃色av| 成人av中文字幕| 国产成人aaaa| 狠狠色丁香久久婷婷综合_中| 免费av成人在线| 亚洲成人777| 亚洲成人福利片| 亚洲国产成人tv| 亚洲主播在线播放| 亚洲欧美另类综合偷拍| 亚洲欧美一区二区三区孕妇| 最新热久久免费视频| 蜜桃视频在线一区| 奇米四色…亚洲| 麻豆91免费观看| 黄色资源网久久资源365| 精久久久久久久久久久| 精品一区二区三区久久久| 美女网站在线免费欧美精品| 蜜桃av噜噜一区二区三区小说| 日韩成人一级片| 青青草一区二区三区| 久久国产精品色婷婷| 国产一区二区三区在线观看免费视频 | 国产一区二区三区在线观看精品| 亚洲男人的天堂一区二区| 日韩一级精品视频在线观看| 99re热视频精品| 94-欧美-setu| 精品视频在线免费看| 欧美日韩日日夜夜| 欧美男女性生活在线直播观看| 6080亚洲精品一区二区| 日韩一区二区三区四区| 欧美精品一区二区三区四区| 久久丝袜美腿综合| 国产精品乱人伦一区二区| 亚洲欧美经典视频| 午夜精品在线看| 毛片av一区二区三区| 丰满放荡岳乱妇91ww| 91美女视频网站| 7777精品伊人久久久大香线蕉超级流畅 | 色综合天天做天天爱| 99re亚洲国产精品| 91免费视频大全| 2023国产精品| 久久婷婷色综合| 最新日韩在线视频| 偷拍一区二区三区| 国产一区二区三区精品欧美日韩一区二区三区 | 日本一区二区三区视频视频| 国产亚洲女人久久久久毛片| 国产精品蜜臀av| 一区二区三区国产精华| 免费成人av在线播放| 不卡区在线中文字幕| 欧美日韩国产影片| 久久精品视频免费| 亚洲一区二区不卡免费| 激情深爱一区二区| 91麻豆swag| 日韩视频123| 亚洲欧洲精品一区二区精品久久久| 亚洲国产精品一区二区久久 | 欧美天堂亚洲电影院在线播放| 日韩欧美一区二区免费| 国产精品萝li| 久久99久国产精品黄毛片色诱| 日韩欧美国产小视频| 日韩理论片在线| 久久99精品久久久久婷婷| 91免费观看国产| 精品欧美黑人一区二区三区| 中文字幕综合网| 裸体健美xxxx欧美裸体表演| 91在线免费播放| 精品美女在线观看| 亚洲综合视频在线| 成人av资源站| 久久亚洲一区二区三区四区| 午夜视黄欧洲亚洲| 成人动漫精品一区二区| 欧美不卡一区二区| 亚洲线精品一区二区三区八戒| 国产成人免费视频网站| 91精品国产麻豆国产自产在线 | 精品一区二区在线观看| 色婷婷综合久久久中文一区二区 | 在线看国产一区二区| 久久久蜜臀国产一区二区| 午夜视频一区在线观看| 色成人在线视频| 亚洲视频在线观看一区| 国产精品一区二区三区网站| 欧美成人精品二区三区99精品| 亚洲成在人线免费| 91久久精品国产91性色tv| 韩国女主播成人在线| 欧美一区二区视频在线观看2022| 有码一区二区三区| 成人高清在线视频| 中文字幕va一区二区三区| 国产成人综合视频| 久久亚洲精精品中文字幕早川悠里| 日韩成人午夜精品| 91精品国产日韩91久久久久久| 五月天亚洲精品| 777久久久精品| 日韩不卡一区二区| 69久久夜色精品国产69蝌蚪网 | 国产白丝精品91爽爽久久| 精品日本一线二线三线不卡| 精品写真视频在线观看| 精品国产一区二区在线观看| 国产一区二区中文字幕| 欧美精品一区二区三区四区| 国产乱码精品一区二区三区五月婷| 久久亚洲欧美国产精品乐播| 狠狠色综合色综合网络| 久久久国产一区二区三区四区小说 | 色久优优欧美色久优优| 亚洲欧美日本在线| 91久久线看在观草草青青| 亚洲主播在线观看| 欧美精品久久天天躁| 午夜天堂影视香蕉久久| 5月丁香婷婷综合| 久久国产人妖系列| 久久久亚洲精品一区二区三区 | 久久国产精品色| 久久久蜜臀国产一区二区| 成人av资源站| 亚洲国产精品欧美一二99| 欧美久久一二三四区| 精品一区二区免费视频| 国产日产欧美一区| 色综合久久综合网| 天天操天天色综合| 久久久久久**毛片大全| 91视频你懂的| 免费欧美日韩国产三级电影| 国产视频在线观看一区二区三区| 99久久免费国产| 日韩在线一区二区| 亚洲精品一区二区三区福利| 波多野结衣视频一区| 亚洲国产日韩精品| 精品国产99国产精品| 99在线热播精品免费| 天天色图综合网| 国产精品免费av| 亚洲人成7777| 日韩欧美一级片| 色伊人久久综合中文字幕| 奇米综合一区二区三区精品视频| 欧美激情中文字幕一区二区| 欧美天堂一区二区三区| 国产乱国产乱300精品| 亚洲国产中文字幕| 国产日产欧美一区二区三区| 精品1区2区3区| 福利视频网站一区二区三区| 亚洲成在人线免费| 国产精品丝袜久久久久久app| 欧美色倩网站大全免费| 国产馆精品极品| 日韩精品视频网| 亚洲欧美日韩国产综合| 欧美成人乱码一区二区三区| 欧美在线色视频| 成人午夜又粗又硬又大| 日韩黄色在线观看| 国产精品国产三级国产aⅴ无密码| 日韩欧美成人激情| 欧美中文字幕一二三区视频| 成人开心网精品视频| 精品亚洲国内自在自线福利| 亚洲风情在线资源站| 国产精品激情偷乱一区二区∴|