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

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

?? sbindyserveriohandler10.pas

?? 著名的SecureBlackBox控件完整源碼
?? PAS
?? 第 1 頁 / 共 2 頁
字號:

(******************************************************)
(*                                                    *)
(*            EldoS SecureBlackbox Library            *)
(*                                                    *)
(*      Copyright (c) 2002-2007 EldoS Corporation     *)
(*           http://www.secureblackbox.com            *)
(*                                                    *)
(******************************************************)

unit SBIndyServerIOHandler10;

interface

// Please uncomment the following conditional define if you are using
// Indy 10.1.1 or higher
{$define INDY1011}

uses
  SBIndyIOHandler10, Classes, IdSSL, SBUtils, SBClient, IdAntiFreezeBase,
  IdStack, IdGlobalProtocols, IdStackConsts, IdGlobal, SBConstants, SBX509,
  SBCustomCertStorage, SBServer, SBSessionPool, IdThread, IdScheduler,
  IdIOHandler, IdSocketHandle, IdYarn, SBSSLConstants, SBSSLCommon;

type

  TElClientServerIndySSLIOHandlerSocket = class;

  TSBIndyIOHandlerCertificateValidateEvent = procedure(Sender: TObject;
    X509Certificate: TElX509Certificate; IOHandler: TElClientServerIndySSLIOHandlerSocket;
    var Validate: boolean) of object;

  TElClientServerIndySSLIOHandlerSocket = class(TElClientIndySSLIOHandlerSocket)
  private
    function GetClientAuthentication : boolean;
    function GetServerCertStorage : TElMemoryCertStorage;
    function GetSessionPool : TElSessionPool;
    procedure HandleCertificateValidate(Sender: TObject; X509Certificate:
        TElX509Certificate; var Validate: boolean);
    //procedure HandleCiphersNegotiated(Sender : TObject);
    //procedure HandleError(Sender : TObject; ErrorCode: integer; Fatal: boolean;
    //    Remote : boolean);
    procedure SetClientAuthentication(Value : boolean);
    procedure SetServerCertStorage(Value : TElMemoryCertStorage);
    procedure SetSessionPool(Value : TElSessionPool);
    //procedure HandleCiphersNegotiated(Sender: TObject);
    //procedure HandleError(Sender: TObject; ErrorCode: integer; Fatal,
    //  Remote: boolean);
  protected
    FSecureServer : TElSecureServer;
    procedure DoSSLEstablished; override;
    function GetCipherSuite : TSBCipherSuite; override;
    function GetVersion : TSBVersion; override;
    function GetAuthenticationLevel : TSBAuthenticationLevel;
    function GetCompressionAlgorithm: TSBSSLCompressionAlgorithm; override;
    function GetForceCertificateChain : boolean;
    procedure InitComponent; override;
    procedure OnSecureServerCloseConnection(Sender : TObject; CloseReason :
      integer);
    function ReadFromSource(ARaiseExceptionIfDisconnected: Boolean = True;
      ATimeout: Integer = IdTimeoutDefault;
      ARaiseExceptionOnTimeout: Boolean = True): Integer; override;
    procedure SetCertStorage(Value : TElCustomCertStorage); override;
    procedure SetCipherSuites(Index : TSBCipherSuite; Value : boolean); override;
    procedure SetOnCertificateValidate(Value : TSBCertificateValidateEvent); override;
    procedure SetOnCiphersNegotiated(Value: TNotifyEvent); override;
    procedure SetOnError(Value: TSBErrorEvent); override;

    procedure SetVersions(Value : TSBVersions); override;
    procedure SetAuthenticationLevel(Value : TSBAuthenticationLevel);
    procedure SetCompressionAlgorithms(Index: TSBSSLCompressionAlgorithm; Value:
        boolean); override;
    procedure SetForceCertificateChain(Value : boolean);
  protected
    FOnCertificateValidate: TSBIndyIOHandlerCertificateValidateEvent;
  public
    function Clone :  TIdSSLIOHandlerSocketBase; override;
    procedure Close; override;
    function Connected: Boolean; override;
    destructor Destroy; override;
    procedure InternalValidate(var Validity: TSBCertificateValidity; var Reason:
        TSBCertificateValidityReason);
    procedure RenegotiateCiphers; reintroduce;
    procedure StartSSL; override;
    { if you got an error here, please see the comment on the top of the unit }
    {$ifndef INDY1011}
    procedure WriteDirect(ABuffer: TIdBytes); override;
    {$else}
    procedure WriteDirect(var ABuffer: TIdBytes); override;
    {$endif}
  published
    property OnCertificateValidate: TSBIndyIOHandlerCertificateValidateEvent read
        FOnCertificateValidate write FOnCertificateValidate;
    property ClientAuthentication : boolean read GetClientAuthentication
      write SetClientAuthentication;
    property AuthenticationLevel : TSBAuthenticationLevel read GetAuthenticationLevel
      write SetAuthenticationLevel;
    property ForceCertificateChain : boolean read GetForceCertificateChain
      write SetForceCertificateChain;
    property ServerCertStorage : TElMemoryCertStorage read GetServerCertStorage
      write SetServerCertStorage;
    property SessionPool : TElSessionPool read GetSessionPool write SetSessionPool;
  end;

  TElIndySSLServerIOHandler = class(TIdServerIOHandlerSSLBase)
  private
    FCertStorage : TElCustomCertStorage;
    FCipherSuites : array[SB_SUITE_FIRST..SB_SUITE_LAST] of boolean;
    FCompressionAlgorithms : array[TSBSSLCompressionAlgorithm] of boolean;
    FClientAuthentication : boolean;
    FAuthenticationLevel : TSBAuthenticationLevel;
    FForceCertificateChain : boolean;
    FOnCertificateNeeded: TSBCertificateNeededEvent;
    FOnCertificateNeededEx: TSBCertificateNeededExEvent;
    FOnCertificateValidate: TSBIndyIOHandlerCertificateValidateEvent;
    FOnSSLEstablished: TSBSSLEstablishedEvent;
    FPassthrough : boolean;
    FServerCertStorage : TElMemoryCertStorage;
    FSessionPool : TElSessionPool;
    FVersions : TSBVersions;
    procedure HandleCertificateValidate(Sender: TObject; X509Certificate:
        TElX509Certificate; IOHandler: TElClientServerIndySSLIOHandlerSocket; var
        Validate: boolean);
    procedure HandleCiphersNegotiated(Sender : TObject);
    procedure HandleError(Sender : TObject; ErrorCode: integer; Fatal: boolean;
        Remote : boolean);
    procedure HandleSSLEstablished(Sender : TObject; Version : TSBVersion;
        CipherSuite : TSBCipherSuite);
  protected
    FOnCiphersNegotiated: TNotifyEvent;
    FOnError: TSBErrorEvent;
    procedure CopySSLParams(IOHandler : TElClientServerIndySSLIOHandlerSocket);
    function GetCipherSuites(Index : TSBCipherSuite) : boolean;
    function GetCompressionAlgorithms(Index: TSBSSLCompressionAlgorithm): boolean;
    procedure Notification(AComponent : TComponent; AOperation : TOperation); override;
    procedure SetCertStorage(Value : TElCustomCertStorage);
    procedure SetCipherSuites(Index : TSBCipherSuite; Value : boolean);
    procedure SetCompressionAlgorithms(Index: TSBSSLCompressionAlgorithm; Value:
        boolean);
    procedure SetServerCertStorage(Value : TElMemoryCertStorage);
    procedure SetSessionPool(Value : TElSessionPool);
  public
    function Accept(ASocket: TIdSocketHandle; AListenerThread: TIdThread;
      AYarn: TIdYarn): TIdIOHandler; override;
    procedure Init; override;
    procedure InitComponent; override;
    function MakeClientIOHandler : TIdSSLIOHandlerSocketBase; override;
    function MakeClientIOHandler(ATheThread:TIdYarn ): TIdIOHandler; overload; override;
    function MakeFTPSvrPasv : TIdSSLIOHandlerSocketBase; override;
    function MakeFTPSvrPort : TIdSSLIOHandlerSocketBase; override;
    procedure SetScheduler(AScheduler:TIdScheduler); override;
    property CipherSuites[Index : TSBCipherSuite] : boolean read GetCipherSuites
      write SetCipherSuites;
    property CompressionAlgorithms[Index: TSBSSLCompressionAlgorithm]: boolean read
        GetCompressionAlgorithms write SetCompressionAlgorithms;
  published
    property CertStorage : TElCustomCertStorage read FCertStorage
      write SetCertStorage;
    property ClientAuthentication : boolean read FClientAuthentication
      write FClientAuthentication;
    property AuthenticationLevel : TSBAuthenticationLevel read FAuthenticationLevel
      write FAuthenticationLevel default alRequireCert;
    property ForceCertificateChain : boolean read FForceCertificateChain
      write FForceCertificateChain default false;
    property OnCertificateNeeded: TSBCertificateNeededEvent read
        FOnCertificateNeeded write FOnCertificateNeeded;
    property OnCertificateNeededEx: TSBCertificateNeededExEvent read
        FOnCertificateNeededEx write FOnCertificateNeededEx;
    property OnCertificateValidate: TSBIndyIOHandlerCertificateValidateEvent read
        FOnCertificateValidate write FOnCertificateValidate;
    property OnCiphersNegotiated: TNotifyEvent read FOnCiphersNegotiated write
        FOnCiphersNegotiated;
    property OnError: TSBErrorEvent read FOnError write FOnError;
    property OnSSLEstablished: TSBSSLEstablishedEvent read FOnSSLEstablished write
        FOnSSLEstablished;
    property Passthrough : boolean read FPassthrough write FPassthrough
      default true;
    property ServerCertStorage : TElMemoryCertStorage read FServerCertStorage
      write SetServerCertStorage;
    property SessionPool : TElSessionPool read FSessionPool write SetSessionPool;
    property Versions : TSBVersions read FVersions write FVersions;
  end;

procedure Register;

implementation

uses
  Sysutils, IdException, IdExceptionCore, IdResourceStrings, IdResourceStringsCore,
  IdResourceStringsProtocols;

procedure Register;
begin
  RegisterComponents('SSLBlackbox', [TElClientServerIndySSLIOHandlerSocket,
    TElIndySSLServerIOHandler]);
end;                         

function TElClientServerIndySSLIOHandlerSocket.GetClientAuthentication : boolean;
begin
  Result := FSecureServer.ClientAuthentication;
end;

function TElClientServerIndySSLIOHandlerSocket.GetServerCertStorage : TElMemoryCertStorage;
begin
  Result := FSecureServer.CertStorage;
end;

function TElClientServerIndySSLIOHandlerSocket.GetSessionPool : TElSessionPool;
begin
  Result := FSecureServer.SessionPool;
end;

function TElClientServerIndySSLIOHandlerSocket.GetAuthenticationLevel : TSBAuthenticationLevel;
begin
  Result := FSecureServer.AuthenticationLevel;
end;

function TElClientServerIndySSLIOHandlerSocket.GetForceCertificateChain : boolean;
begin
  Result := FSecureServer.ForceCertificateChain;
end;

procedure TElClientServerIndySSLIOHandlerSocket.HandleCertificateValidate(
    Sender: TObject; X509Certificate: TElX509Certificate; var Validate:
    boolean);
begin
  if Assigned(FOnCertificateValidate) then
    FOnCertificateValidate(Self, X509Certificate, Self, Validate);
end;

procedure TElClientServerIndySSLIOHandlerSocket.SetClientAuthentication(Value : boolean);
begin
  FSecureServer.ClientAuthentication := Value;
end;

procedure TElClientServerIndySSLIOHandlerSocket.SetServerCertStorage(Value : TElMemoryCertStorage);
begin
  FSecureServer.CertStorage := Value;
end;

procedure TElClientServerIndySSLIOHandlerSocket.SetSessionPool(Value : TElSessionPool);
begin
  FSecureServer.SessionPool := Value;
end;

procedure TElClientServerIndySSLIOHandlerSocket.SetAuthenticationLevel(Value : TSBAuthenticationLevel);
begin
  FSecureServer.AuthenticationLevel := Value;
end;

procedure TElClientServerIndySSLIOHandlerSocket.SetForceCertificateChain(Value : boolean);
begin
  FSecureServer.ForceCertificateChain := Value;
end;

procedure TElClientServerIndySSLIOHandlerSocket.DoSSLEstablished;
begin
  if Assigned(FOnSSLEstablished) then
    FOnSSLEstablished(Self, FSecureServer.CurrentVersion, FSecureServer.CipherSuite);
end;

function TElClientServerIndySSLIOHandlerSocket.GetCipherSuite : TSBCipherSuite;
begin
  if FIsPeer then
    Result := FSecureServer.CipherSuite
  else
    Result := FSecureClient.CipherSuite;
end;

function TElClientServerIndySSLIOHandlerSocket.GetVersion : TSBVersion;
begin
  if FIsPeer then
    Result := FSecureServer.CurrentVersion
  else
    Result := FSecureClient.CurrentVersion;
end;

////////////////////////////////////////////////////////////////////////////////
// TElClientServerIndySSLIOHandlerSocket class

procedure TElClientServerIndySSLIOHandlerSocket.InitComponent;
var
  I : integer;
begin
  inherited;
  FSecureServer := TElSecureServer.Create(nil);
  for I := SB_SUITE_FIRST to SB_SUITE_LAST do
    FSecureServer.CipherSuites[I] := FSecureClient.CipherSuites[I];
  FSecureServer.Versions := FSecureClient.Versions;
  FSecureServer.OnCloseConnection := OnSecureServerCloseConnection;
  FSecureServer.OnCertificateValidate := HandleCertificateValidate;
  //FSecureServer.OnError := HandleError;
  //FSecureServer.OnCiphersNegotiated := HandleCiphersNegotiated; 
end;

procedure TElClientServerIndySSLIOHandlerSocket.OnSecureServerCloseConnection(Sender :
  TObject; CloseReason : integer);
begin
  FErrorOccured := true;
end;

function TElClientServerIndySSLIOHandlerSocket.ReadFromSource(ARaiseExceptionIfDisconnected:
  Boolean = True; ATimeout: Integer = IdTimeoutDefault;
  ARaiseExceptionOnTimeout: Boolean = True): Integer;
var
  Buf: TIdBytes;
  Written : integer;
begin
  Result := 0;
  SetLength(Buf, 16384);
  if (FSecured) and (not FPassThrough) then
  begin
    if FErrorOccured then
    begin
      Result := 1;
      FClosedGracefully := true;
      if ARaiseExceptionIfDisconnected then
      begin
        ForceClose := true;
        raise EIdConnClosedGracefully.Create('Disconnected');
      end;
    end
    else
    begin
      if Assigned(FBinding) and (FBinding.Readable(ATimeout)) then
      begin
        if FIsPeer then
          FSecureServer.DataAvailable
        else
          FSecureClient.DataAvailable;
      end;
    end;
  end
  else 
  begin
    if ATimeOut = 0 then
    begin
      Result := inherited ReadFromSource(ARaiseExceptionIfDisconnected, ATimeOut,
        ARaiseExceptionOnTimeOut);
      Exit;
    end;
    if Assigned(FBinding) and (FBinding.Readable(ATimeout)) then
    begin
      Written := FBinding.Receive(Buf);
      if Written <= 0 then
      begin
        FErrorOccured := true;
        Result := 1;
        FClosedGracefully := true;
        if ARaiseExceptionIfDisconnected then
          raise EIdConnClosedGracefully.Create('Error while reading from socket');
      end
      else
      begin
        SetLength(Buf, Written);
        if Assigned(Intercept) then
        begin
          Intercept.Receive(Buf);
        end;
        FInputBuffer.Write(Buf);
      end;
    end
    else
      Result := 1;
  end;
end;

procedure TElClientServerIndySSLIOHandlerSocket.SetCertStorage(Value : TElCustomCertStorage);
begin
  inherited SetCertStorage(Value);
  FSecureServer.ClientCertStorage := Value;
end;

procedure TElClientServerIndySSLIOHandlerSocket.SetCipherSuites(Index : TSBCipherSuite;
  Value : boolean);
begin
  inherited SetCipherSuites(Index, Value);
  FSecureServer.CipherSuites[Index] := Value;  
end;

procedure TElClientServerIndySSLIOHandlerSocket.SetOnCertificateValidate(Value :
  TSBCertificateValidateEvent);
begin
  inherited SetOnCertificateValidate(Value);
  FSecureServer.OnCertificateValidate := Value;  
end;

procedure TElClientServerIndySSLIOHandlerSocket.SetVersions(Value : TSBVersions);
begin
  inherited SetVersions(Value);
  FSecureServer.Versions := Value;
end;

function TElClientServerIndySSLIOHandlerSocket.Clone :  TIdSSLIOHandlerSocketBase;
var
  IOHandler : TElClientServerIndySSLIOHandlerSocket;
  I : integer;
begin
  IOHandler := TElClientServerIndySSLIOHandlerSocket.Create(nil);
  IOHandler.Versions := Versions;
  for I := SB_SUITE_FIRST to SB_SUITE_LAST do
    IOHandler.CipherSuites[I] := CipherSuites[I];
  IOHandler.CertStorage := CertStorage;
  IOHandler.ServerCertStorage := ServerCertStorage;
  IOHandler.SessionPool := SessionPool;
  IOHandler.ClientAuthentication := ClientAuthentication;
  IOHandler.OnCertificateValidate := OnCertificateValidate;
  IOHandler.OnCertificateNeeded := OnCertificateNeeded;
  IOHandler.OnCertificateNeededEx := OnCertificateNeededEx;
  IOHandler.OnError := OnError;
  IOHandler.OnCiphersNegotiated := OnCiphersNegotiated;
  IOHandler.PassThrough := FPassThrough;
  IOHandler.AuthenticationLevel := AuthenticationLevel;
  IOHandler.ForceCertificateChain := ForceCertificateChain;
  Result := IOHandler;
end;

procedure TElClientServerIndySSLIOHandlerSocket.Close;
begin

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美一区二区三区视频免费| 亚洲精品一线二线三线无人区| 亚洲午夜精品在线| 国产传媒一区在线| 国内精品久久久久影院一蜜桃| 欧美一区二区精品| 丁香激情综合国产| 91精彩视频在线观看| 欧美成人乱码一区二区三区| 中文字幕一区日韩精品欧美| 国产一区二区导航在线播放| 中文字幕一区二区不卡| 久久久夜色精品亚洲| 久久精品国内一区二区三区| 中文字幕在线免费不卡| 亚洲成人动漫一区| 亚洲午夜电影在线| 亚洲国产乱码最新视频 | 亚洲成av人综合在线观看| 久久看人人爽人人| 国产日韩三级在线| 一区二区激情视频| 欧美乱妇23p| 日韩视频免费观看高清完整版在线观看 | 国产在线精品国自产拍免费| 国内精品国产成人国产三级粉色| 欧美日韩在线亚洲一区蜜芽| 在线观看日韩国产| 国产日韩欧美高清在线| 欧美一区二区视频网站| 色综合久久综合中文综合网| 欧美一区二区三区思思人| 欧美v国产在线一区二区三区| 93久久精品日日躁夜夜躁欧美| 欧美午夜在线一二页| 欧美四级电影网| 色老汉一区二区三区| 中文字幕一区二区三区不卡| 91精品国产免费久久综合| 日韩一区二区三区观看| 高清在线成人网| 粉嫩在线一区二区三区视频| 久久成人久久鬼色| 不卡一区二区在线| 国产色91在线| 蜜臀av性久久久久蜜臀aⅴ| 中文字幕欧美区| 另类欧美日韩国产在线| 中文字幕不卡的av| 国产欧美中文在线| 激情欧美日韩一区二区| 国产亚洲短视频| 欧美日韩一级视频| 国产精品久久久久久久久免费相片 | 不卡一区二区三区四区| 91国产免费观看| 99热国产精品| 欧美在线观看一二区| 日韩一区二区电影| 日本不卡一区二区三区 | 99久久国产综合精品麻豆| 国产在线播精品第三| 尤物av一区二区| 国模冰冰炮一区二区| 国产亚洲精久久久久久| 国产精品第一页第二页第三页| 亚洲精品国产成人久久av盗摄 | 午夜精品久久久久| 日韩一级高清毛片| 67194成人在线观看| 亚洲精品在线电影| 国产**成人网毛片九色| 国产亚洲欧洲997久久综合| 欧美性受xxxx黑人xyx性爽| 7777精品伊人久久久大香线蕉超级流畅 | 又紧又大又爽精品一区二区| 在线观看av一区| 亚洲精品网站在线观看| 91成人看片片| 欧美最新大片在线看| 国产自产高清不卡| 一区二区三区中文免费| 亚洲图片自拍偷拍| 日本一区二区三区电影| 中文字幕综合网| 国产一区二区在线观看免费 | 色狠狠色噜噜噜综合网| 91蜜桃在线观看| 狠狠色综合播放一区二区| 欧美撒尿777hd撒尿| 精品在线一区二区| 91猫先生在线| 婷婷综合久久一区二区三区| 国产成人免费9x9x人网站视频| 国产精品538一区二区在线| 国产视频在线观看一区二区三区 | 蜜臀av在线播放一区二区三区| 国产一区二区女| 欧美调教femdomvk| 日韩激情视频在线观看| 色噜噜狠狠一区二区三区果冻| 欧美一卡2卡3卡4卡| 亚洲欧美偷拍另类a∨色屁股| 91精品国产91久久久久久最新毛片| 久久99在线观看| 欧美一区二区三区成人| 午夜精品久久久久久久99水蜜桃| 一本一本大道香蕉久在线精品| 国产高清精品在线| 中文字幕精品在线不卡| 欧美日韩一本到| 亚洲乱码日产精品bd| 一区二区中文字幕在线| 国产精品一区二区果冻传媒| 国内精品在线播放| 丝袜诱惑制服诱惑色一区在线观看 | 懂色av一区二区夜夜嗨| 国产麻豆精品95视频| 欧美性大战久久| 亚洲激情图片一区| 暴力调教一区二区三区| 国产精品国产三级国产aⅴ中文| 蜜桃av噜噜一区| 久久久亚洲综合| 亚洲精品一区二区三区影院 | 免费日韩伦理电影| 在线一区二区观看| 久久久久久久久免费| 国产精品123区| 久久婷婷成人综合色| 精品成人一区二区三区| 色婷婷精品大在线视频| 水野朝阳av一区二区三区| 不卡在线视频中文字幕| youjizz国产精品| 中文字幕乱码亚洲精品一区 | 日韩精品成人一区二区在线| 亚洲综合免费观看高清完整版 | 日韩视频在线一区二区| 日韩黄色免费网站| 国产成人av电影在线| 欧美日韩你懂得| 成人性生交大片免费看在线播放| www.亚洲人| 国产精品久久久久久久久免费相片| 91免费看视频| 国产成人精品免费视频网站| 国产福利不卡视频| 精品国产免费视频| 日韩成人一级片| 国产精品不卡一区| 久久奇米777| 欧美日本一区二区| 久久众筹精品私拍模特| 国产欧美精品日韩区二区麻豆天美 | 久久国产日韩欧美精品| 国产剧情一区在线| 国产精品中文欧美| 波多野结衣一区二区三区| 欧美日韩免费在线视频| 国内精品伊人久久久久av影院| 欧美日韩国产天堂| 日韩高清国产一区在线| 青娱乐精品在线视频| 天堂成人免费av电影一区| 亚洲天堂免费在线观看视频| 日本大胆欧美人术艺术动态| 亚洲欧美一区二区三区久本道91| 日韩黄色免费电影| 欧美精选一区二区| 精品一区二区三区久久久| 91国偷自产一区二区开放时间| 国产日韩欧美在线一区| 亚洲美女淫视频| 麻豆精品国产91久久久久久| 99精品视频一区二区三区| 欧美综合欧美视频| 99国产精品99久久久久久| 欧美综合视频在线观看| 国产日韩欧美亚洲| 成人黄色电影在线| 日韩三级伦理片妻子的秘密按摩| 成人97人人超碰人人99| 精品国产免费人成在线观看| 成人av小说网| 精品久久一区二区三区| 亚洲天堂中文字幕| 午夜视频在线观看一区二区 | 色先锋久久av资源部| 久久99久久99精品免视看婷婷| 久久国产尿小便嘘嘘尿| 精品久久一区二区| 欧美不卡一区二区| 久久久久久免费毛片精品| 日韩精品一级中文字幕精品视频免费观看| 亚洲日本成人在线观看| 成人黄色软件下载| 亚洲精品精品亚洲| 日韩av一级片| 国产精品白丝jk黑袜喷水|