delphi7的加密算法与 delphi XE+加解密算法

delphi7的加密算法与 delphi XE+加解密算法

delphi7加解密算法:

Function JiaMi(Src:String; Key:String):String;
var
  KeyLen :Integer;
  KeyPos :Integer;
  offset :Integer;
  dest :String;
  SrcPos :Integer;
  SrcAsc :Integer;
  Range :Integer;
begin
  KeyLen:=Length(Key);
  KeyPos:=0;
  Range:=1;
  Randomize;
  offset:=Random(Range);
  dest:=format('%1.2x',[offset]);
  for SrcPos := 1 to Length(Src) do
  begin
    SrcAsc:=(Ord(Src[SrcPos]) + offset) MOD 255;
    if KeyPos < KeyLen then KeyPos:= KeyPos + 1 else KeyPos:=1;
    SrcAsc:= SrcAsc xor Ord(Key[KeyPos]);
    dest:=dest + format('%1.2x',[SrcAsc]);
    offset:=SrcAsc;
  end;
  Result:=Dest;
end;     
//解密函数
Function JieMi (Src:String; Key:String):String;
var
  KeyLen :Integer;
  KeyPos :Integer;
  offset :Integer;
  dest :String;
  SrcPos :Integer;
  SrcAsc :Integer;
  TmpSrcAsc :Integer;
  Range :Integer;
begin
  KeyLen:=Length(Key);
  if KeyLen = 0 then key:='starlin';
  KeyPos:=0;
  SrcPos:=0;
  SrcAsc:=0;
  Range:=1;
  offset:=StrToInt('$'+ copy(src,1,2));
  SrcPos:=3;
  repeat
    try
      SrcAsc:=StrToInt('$'+ copy(src,SrcPos,2));
    except
      SrcAsc:=StrToInt('$00');
    end;
    if KeyPos < KeyLen Then KeyPos := KeyPos + 1 else KeyPos := 1;
    TmpSrcAsc := SrcAsc xor Ord(Key[KeyPos]);
    if TmpSrcAsc <= offset then
      TmpSrcAsc := 255 + TmpSrcAsc - offset
    else
      TmpSrcAsc := TmpSrcAsc - offset;
    dest := dest + chr(TmpSrcAsc);
    offset:=srcAsc;
    SrcPos:=SrcPos + 2;
  until SrcPos >= Length(Src);
  Result:=Dest;
  Result:=Copy(Result,1,Length(Result)-1);
end;     
end.

Delphi XE+版本:

Function JiaMi(Src:String; Key:String):String;
// Src 支持汉字,字母,数字,符号
// Key 不支持汉字;适合字母与数字
var
  KeyLen :Integer;
  KeyPos :Integer;
  offset :Integer;
  dest :String;
  SrcPos :Integer;
  SrcAsc :Integer;
  Range :Integer;
  IntTemp:integer;
  SrcAnsi:PAnsiChar;

begin
  KeyLen:=Length(Key);
  KeyPos:=0;
  Range:=1;
  Randomize;
  offset:=Random(Range);
  dest:=format('%1.2x',[offset]);
  SrcAnsi:=PAnsiChar(AnsiString(Src));
  IntTemp:= Length(SrcAnsi);
  for SrcPos := 1 to IntTemp do

  begin
    SrcAsc:=(Ord(SrcAnsi[SrcPos-1]) + offset) MOD 255;
    if KeyPos < KeyLen then KeyPos:= KeyPos + 1 else KeyPos:=1;
    SrcAsc:= SrcAsc xor Ord(Key[KeyPos]);
    dest:=dest + format('%1.2x',[SrcAsc]);
    offset:=SrcAsc;
  end;

  Result:=Dest;
end;

//解密函数
Function JieMi (Src:String; Key:String):String;
// Src 支持汉字,字母,数字,符号
// Key 不支持汉字;适合字母与数字
var
  KeyLen :Integer;
  KeyPos :Integer;
  offset :Integer;
  dest :String;
  SrcPos :Integer;
  SrcAsc :Integer;
  TmpSrcAsc :Integer;
  Range :Integer;
  SrcAnsi:PAnsiChar;
  IntTemp,i:Integer;
  ByteArray: array of Byte;
begin
  KeyLen:=Length(Key);
  if KeyLen = 0 then key:='starlin';
  KeyPos:=0;
  SrcPos:=0;
  SrcAsc:=0;
  Range:=1;
  offset:=StrToInt('$'+ copy(src,1,2));
  SrcPos:=3;
  IntTemp:=Length(Src) div 2;
  setlength(ByteArray,IntTemp);
  i:=0;
  repeat
    try
      SrcAsc:=StrToInt('$'+ copy(src,SrcPos,2));
    except
      SrcAsc:=StrToInt('$00');
    end;    
    if KeyPos < KeyLen Then KeyPos := KeyPos + 1 else KeyPos := 1;    
    TmpSrcAsc := SrcAsc xor Ord(Key[KeyPos]);    
    if TmpSrcAsc <= offset then
      TmpSrcAsc := 255 + TmpSrcAsc - offset
    else
      TmpSrcAsc := TmpSrcAsc - offset;
    ByteArray[i]:=TmpSrcAsc;
    i:=i+1;           
    offset:=srcAsc;
    SrcPos:=SrcPos + 2;
  until SrcPos >= Length(Src);
  GetMem(SrcAnsi,IntTemp+1); 
  CopyMemory(@SrcAnsi[0],@ByteArray[0],IntTemp);
  dest:=string(strpas(SrcAnsi));     
  Result:=Dest; 
end;

测试:
str1 :=jiemi(jiami(‘学习ABC123’,‘uabd123’),‘uabd123’);
//返回值:学习ABC123

  • 1
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
Delphi 7和Java是两种不同的编程语言,它们具有不同的工作原理和语法,因此在进行AES加密解密和相互转换时需要特定的步骤。 1. Delphi 7的AES加密解密: - Delphi 7可以使用第三方库来实现AES加密解密,例如DCPCrypt或DelphiEncryptionCompendium等。 - 使用这些库,你可以在Delphi 7中调用AES加密解密方法来处理需要加密解密的数据。 - 对于加密操作,你需要提供明文,密钥和加密模式等参数。对于解密操作,你需要提供密文,密钥和解密模式等参数。 2. Delphi 7到Java的转换: - 在将Delphi 7中的AES加密解密逻辑转换到Java时,你需要使用Java的加密类库,例如Java Cryptography Extension(JCE)。 - 在Java中,你可以使用javax.crypto包中的Cipher类来实现AES加密解密操作。 - 你需要提供相应的参数,例如密钥,加密算法和填充模式等来执行加密解密操作。 3. Java到Delphi 7的转换: - 在将Java中的AES加密解密逻辑转换到Delphi 7时,你需要使用Delphi 7的加密类库,如前面提到的DCPCrypt或DelphiEncryptionCompendium等。 - 你可以使用对应的加密方法和相应的参数(如密钥和加密算法等)来执行加密解密操作。 - 确保在转换时,密钥和其他相关参数的格式和类型是一致的,以便正确处理数据。 总之,要在Delphi 7和Java之间实现AES加密解密的互转,你需要使用每种语言中的加密库并提供相应的参数。这样可以确保在两种语言之间正确执行加密解密操作。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值