DELPHI 使用indy实现DES/ECB加解密

使用indy实现DES/ECB加解密

最近在使用indy的,时候发现新的indy封装很多加解密的方法,苦于说明的资料太少,大家基本还是在用第三方写的函数库。结合前端时间实现RSA加密的方法,我写了个DES的例子,试了下,base64的编码返回和网上在线加解密的结果是一样的。

还有个问题是,目前只能实现字符串的加密,字节流和字节数组还不会搞…

function DES_Encrypt(key, StrIn: ansistring; bmfs: Integer;
  var strOut: ansistring): Integer; // bmfs: 0 base64,1:hex  编码方式
var
  md_ctx: EVP_CIPHER_CTX;
  nCipher, nTmp, rv: Integer;
  sCipher, sBase64: Array [0 .. 4095] of AnsiChar;
begin
  Result := -1;

  // 初始化密码算法结构体
  EVP_CIPHER_CTX_init(@md_ctx);
  // 设置算法和密钥
  rv := EVP_EncryptInit_ex(@md_ctx, EVP_des_ecb(), Nil, PansiChar(key), nil);
  if rv <> 1 then
  begin
    Result := -2;
    exit;
  end;

  // 数据加密
  rv := EVP_EncryptUpdate(@md_ctx, sCipher, @nCipher, PansiChar(StrIn),
    length(StrIn));

  if rv <> 1 then
  begin
    Result := -3;
    exit;
  end;

  rv := EVP_EncryptFinal_ex(@md_ctx, sCipher + nCipher, @nTmp);

  if rv <> 1 then
  begin
    Result := -4;
    exit;
  end;

  nCipher := nCipher + nTmp;
  case bmfs of
    0:
      strOut := EncodeBase64(@sCipher, nCipher);
    1:
      strOut := strtohex(sCipher);
  end;

  EVP_CIPHER_CTX_cleanup(@md_ctx);
  Result := 0;
end;
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Delphi 7中,可以使用TIdCoderMIME组件来实现DES密,并且满足要求的DES密模式:ECB(Electronic Codebook)和PKCS5Padding(由于DES本身没有内置PKCS5Padding,我们需要手动实现)。最后,我们可以使用TIdEncoderMIME组件将密后的结果进行Base64编码输出。 首先,我们需要在Delphi 7中创建一个新的控制台应用程序。然后,我们需要导入两个组件:TIdCoderMIME和TIdEncoderMIME。您可以在Delphi 7的工具选项卡中,点击"组件",选择"导入类型库",然后选择"Indy MIME Encoding"。 在导入后,您可以在代码中使用这两个组件。以下是一个示例程序: ```Delphi uses SysUtils, IdCoderMIME, IdGlobal; function PKCS5Padding(const Data: TBytes; const BlockSize: Integer): TBytes; var PaddingSize, I: Integer; begin PaddingSize := BlockSize - Length(Data) mod BlockSize; SetLength(Result, Length(Data) + PaddingSize); for I := 0 to Pred(PaddingSize) do Result[Length(Data) + I] := PaddingSize; Move(Data[0], Result[0], Length(Data)); end; function EncryptDES(const Input, Key: AnsiString): AnsiString; var Encoder: TIdEncoderMIME; Coder: TIdEncoder3to4; EncryptedData, EncodedData: TBytes; begin Encoder := TIdEncoderMIME.Create(nil); Coder := TIdEncoder3to4.Create(nil); try EncryptedData := PKCS5Padding(BytesOf(Input), 8); // 设置BlockSize为8,即DES密的块大小 // 使用TIdCoderMIME组件进行DES密 Coder.CodeBytes(EncryptedData, EncryptedData, Length(EncryptedData)); // 使用TIdEncoderMIME组件进行Base64编码 EncodedData := Encoder.EncodeBytes(EncryptedData); Result := StringOf(EncodedData); finally Encoder.Free; Coder.Free; end; end; var Input, Key, EncryptedData: AnsiString; begin try Input := 'Hello World'; // 要密的字符串 Key := 'MyKey123'; // 密密钥 EncryptedData := EncryptDES(Input, Key); Writeln('Encrypted Data: ' + EncryptedData); except on E: Exception do Writeln('Exception: ' + E.Message); end; Readln; end. ``` 请注意,这只是一个简单的示例程序,用于演示如何使用Delphi 7中的TIdCoderMIME和TIdEncoderMIME组件进行DES密。在实际应用中,您可能需要添更多的错误处理和输入验证来增强代码的健壮性和安全性。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值