⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 unit1.pas

📁 著名的SecureBlackBox控件完整源码
💻 PAS
字号:
unit Unit1;

interface

uses
  Windows, Messages, SysUtils, Classes, Graphics, Controls, Forms,
  Dialogs, StdCtrls, ExtCtrls, SBPGP, SBPGPKeys, SBUtils, SBPGPUtils,
  SBPGPStreams, SBPGPConstants;

type
  TfrmMainForm = class(TForm)
    lbInputFileName: TLabel;
    editInputFile: TEdit;
    btnBrowseInputFile: TButton;
    btnBrowseKeyringFile: TButton;
    btnVerify: TButton;
    btnClose: TButton;
    Bevel1: TBevel;
    dlgOpenDialog: TOpenDialog;
    dlgSaveDialog: TSaveDialog;
    pgpReader: TElPGPReader;
    pgpKeyring: TElPGPKeyring;
    lbSignFile: TLabel;
    editSignatureFile: TEdit;
    btnBrowseSignFile: TButton;
    cbKeySelect: TComboBox;
    pgpTempKeyring: TElPGPKeyring;
    lbKeyList: TLabel;
    procedure btnCloseClick(Sender: TObject);
    procedure btnVerifyClick(Sender: TObject);
    procedure btnBrowseKeyringFileClick(Sender: TObject);
    procedure btnBrowseSignFileClick(Sender: TObject);
    procedure btnBrowseInputFileClick(Sender: TObject);
    procedure pgpReaderSignatures(Sender: TObject;
      Signatures: array of TElPGPSignature;
      Validities: array of TSBPGPSignatureValidity);
  private
    { Private declarations }
    procedure LoadKeyring;
    procedure PopulateKeyList;
  public
    { Public declarations }
    procedure VerifyDetached(const strInputFilename : string; const strSignatureFilename : string;
      Keyring : TElPGPKeyring);
  end;

var
  frmMainForm: TfrmMainForm;

implementation

uses KeyringLoadForm, SignaturesForm;

{$R *.dfm}

procedure TfrmMainForm.VerifyDetached(const strInputFilename : string; const strSignatureFilename : string;
  Keyring : TElPGPKeyring);
var
  inFileStream: TFileStream;
  inDetachedSignStream: TFileStream;
begin
  pgpReader.VerifyingKeys := Keyring;
  // create filestream for input file
  inFileStream := TFileStream.Create(strInputFilename, fmOpenRead);
  try
    // create filestream for reading signature file
    inDetachedSignStream := TFileStream.Create(strSignatureFilename, fmOpenRead);
    try
      pgpReader.VerifyDetached(inFileStream, inDetachedSignStream);
    finally
      inDetachedSignStream.Free;
    end;
  finally
    inFileStream.Free;
  end;
  Close;
end;

procedure TfrmMainForm.LoadKeyring;
begin
  if frmKeyringLoad.ShowModal = mrOK then
  begin
    try
      pgpKeyring.Load(frmKeyringLoad.editPubKeyring.Text,
        frmKeyringLoad.editSecKeyring.Text, true);
      PopulateKeyList;
    except
      on E : Exception do
        MessageDlg('Failed to load keyring: ' + E.Message, mtError, [mbOk], 0);
    end;
  end;
end;

procedure TfrmMainForm.btnCloseClick(Sender: TObject);
begin
  Close;
end;

procedure TfrmMainForm.btnVerifyClick(Sender: TObject);
begin
  if not FileExists(editInputFile.Text) then
    MessageDlg('Source file not found', mtError, [mbOk], 0)
  else if editSignatureFile.Text = '' then
    MessageDlg('Please select output file', mtError, [mbOk], 0)
  else if pgpKeyring.SecretCount = 0 then
    MessageDlg('Your keyring does not contain private keys.' +
      'You will not be able to decrypt encrypted files.'#13#10 +
      'Please, select another keyring file.', mtError, [mbOk], 0)
  else if cbKeySelect.ItemIndex = -1 then MessageDlg('Please, select key',
    mtError, [mbOk], 0)
  else
  begin
    if cbKeySelect.Items.Objects[cbKeySelect.ItemIndex] = nil then
    begin
      VerifyDetached(editInputFile.Text, editSignatureFile.Text, pgpKeyring);
    end else
    begin
      pgpTempKeyring.Clear;
      pgpTempKeyring.AddSecretKey(TElPGPSecretKey(cbKeySelect.Items.Objects[cbKeySelect.ItemIndex]));
      VerifyDetached(editInputFile.Text, editSignatureFile.Text, pgpTempKeyring);
    end;
  end;
end;

procedure TfrmMainForm.btnBrowseKeyringFileClick(Sender: TObject);
begin
  LoadKeyring;
end;

procedure TfrmMainForm.btnBrowseInputFileClick(Sender: TObject);
begin
  dlgOpenDialog.Filter := '';
  dlgOpenDialog.Title := 'Please, select file';
  if dlgOpenDialog.Execute then
    editInputFile.Text := dlgOpenDialog.FileName;
end;

procedure TfrmMainForm.btnBrowseSignFileClick(Sender: TObject);
begin
  dlgSaveDialog.Filter := '';
  dlgSaveDialog.Title := 'Please, select file';
  if dlgSaveDialog.Execute then
    editSignatureFile.Text := dlgSaveDialog.FileName;
end;

procedure TfrmMainForm.PopulateKeyList;
var
  I : integer;
  function GetUserFriendlyKeyName(Key : TElPGPSecretKey): string;
  begin
    if Key.PublicKey.UserIDCount > 0 then
      Result := Key.PublicKey.UserIDs[0].Name + ' ';
    Result := Result + '[0x' + KeyID2Str(Key.KeyID, true) + ']';
  end;
begin
  cbKeySelect.Clear;

  cbKeySelect.Items.AddObject('Automatically select the appropriate key', nil);

  for I := 0 to pgpKeyring.SecretCount - 1 do
    cbKeySelect.Items.AddObject(GetUserFriendlyKeyName(pgpKeyring.SecretKeys[I]),
      pgpKeyring.SecretKeys[I]);
end;

procedure TfrmMainForm.pgpReaderSignatures(Sender: TObject;
  Signatures: array of TElPGPSignature;
  Validities: array of TSBPGPSignatureValidity);
begin
  with TfrmSignatures.Create(Self) do
    try
      if cbKeySelect.Items.Objects[cbKeySelect.ItemIndex] = nil then
        // autoselect is used
        Init(Signatures, Validities, pgpKeyring)
        // key was selected manually
      else
        Init(Signatures, Validities, pgpTempKeyring);
      ShowModal;
    finally
      Free;
    end;
end;

initialization
SetLicenseKey('ADDCD14AD06709806817E0B3D7BFD0A2222D536FE156466C5D5FE65DB5DEAE76' + 
  'FFDEBC07E915A5751C12C01C783958872A38E4A5EDA140E7247E0F2E56442A3C' + 
  'F3E9347AD8FDE52083A0DFC86BC00ECB0FD0CF1B51159A2BCB84F6EA6349EF47' + 
  '5C15A59AFCC55F7C3AAD26C279628B5D91B1DC94BD2385354A70CCA3B76101D9' + 
  'F41C84A639FC3CCE4BA8F0CC4A66DCD150114A3F58C1AD46B7B94643741BC20A' + 
  '8DCA83AB921480951B423CAA19EF1863A47CA2C3422E7E5634BED98939A5AE43' + 
  'DE1E4BAD79E66D8A5C973B3455656C8C9B6FF024FADD6CDA02D0F506D98493C8' + 
  'BD1ED7B237DB75FA31F2C82654490CDDDEE24E19939137B9E1DB05508733B22F');


end.

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -