加密解密 C# Delphi 兼容互转


C#:
   
        //解密
        public static string HStrToStr(String sInfo)
        {
            string sResult = "";
            if (String.IsNullOrEmpty(sInfo))
            {
                return sResult = "";
            }
            int iValue = 0; byte rValue = 0;
            int iResultLen=(sInfo.Length >> 1);

            //随机密匙取出来
            rValue = (byte)(sInfo[sInfo.Length - 1]);
            for (int i = 0; i < iResultLen; i++)
            {
                //奇数数列
                int iOS = (i + 1) * 2 - 1;
                int iJS = (i) * 2;
                char cValue = (char)((((byte)(sInfo[iJS]) - 80) << 4) + ((byte)(sInfo[iOS]) - 89));
                cValue = (char)((byte)(cValue) ^ ((i+1) & 0xFF));
                cValue = (char)((byte)(cValue) ^ rValue);

                sResult += "" + cValue;
            }

            return sResult;
        }

        //加密
        public static string StrToHStr(String sInfo)
        {
            string sResult = "";
            if (String.IsNullOrEmpty(sInfo))
            {
                return sResult = "";
            }

            int iValue = 0; byte rValue = 0;
            char[] sDeal = new char[sInfo.Length];
            Random rnd = new Random();
            rValue = (byte)(rnd.Next(60) + 35);
            for (int i = 0; i < sInfo.Length; i++)
            {
                sDeal[i]=(char)((byte)sInfo[i] ^ rValue);
                sDeal[i] = (char)(((byte)sDeal[i]) ^ ((i + 1) & 0xFF));

                sResult += "" +(char)((((byte)(sDeal[i]) & 0xF0) >> 4) + 80) +(char)((((byte)(sDeal[i]) & 0x0F)) + 89);
            }
            //随机密匙放在最后一位。
            sResult += "" + (char)rValue;
            return sResult;
        }


Delphi:

function strtohstr(s: string): string;
var
  i: integer;
  r: byte;
begin
  Randomize;
  r := Random(60) + 35;
  result := '';
  for i := 1 to length(s) do
  begin
    s[i] := chr(ord(s[i]) xor r);
    s[i] := chr(ord(s[i]) xor (i and $FF));
    result := result + chr(((ord(s[i]) and $F0) shr 4) + 80) + chr(((ord(s[i]) and $F)) + 89);
  end;
  result := result + chr(r);
end;

//字符解密

function hstrtostr(s: string): string;
var i: integer;
  c: char;
  r: byte;
begin
  result := '';
  if s = '' then exit;
  r := ord(s[length(s)]);
  for i := 1 to length(s) shr 1 do
  begin
    c := chr(((ord(s[i * 2 - 1]) - 80) shl 4) + (ord(s[i * 2]) - 89));
    c := chr(ord(c) xor (i and $FF));
    c := chr(ord(c) xor r);
    result := result + c;
  end;
end;


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、付费专栏及课程。

余额充值