Avatar billede thomaxz Nybegynder
29. januar 2007 - 12:37 Der er 1 kommentar og
2 løsninger

triple des

jeg har flg. kode

    public static string Bin2Hex(byte[] bin)
        {
            StringBuilder sb = new StringBuilder(bin.Length * 2);
            foreach(byte b in bin) {
                sb.Append(b.ToString("x").PadLeft(2, '0'));
            }
            return sb.ToString();
        }

      public static string tdes_enc(string strToEncrypt)
        {
            byte[] keyz = System.Text.Encoding.ASCII.GetBytes(key);           
            byte[] ivz = System.Text.Encoding.ASCII.GetBytes(iv);
            byte[] data = System.Text.Encoding.ASCII.GetBytes(strToEncrypt);
            byte[] enc = new byte[0];
            System.Security.Cryptography.TripleDES tdes = System.Security.Cryptography.TripleDES.Create();
            tdes.IV = ivz;
            tdes.Key = keyz;
            tdes.Mode = System.Security.Cryptography.CipherMode.CBC;
            tdes.Padding = System.Security.Cryptography.PaddingMode.Zeros;
            System.Security.Cryptography.ICryptoTransform ict = tdes.CreateEncryptor();
            enc = ict.TransformFinalBlock(data, 0, data.Length);
            return Bin2Hex(enc);
        }

men kan ikke få den til at dekrypter har prvøet med

    public static byte[] Hex2Bin(string hex)
        {
            string txt = "";           
            uint hexhold;
            int ytel=0;
            byte[] conv=new byte[(hex.Length/2)+1];
            for (int xtel = 0; xtel < hex.Length; xtel = xtel + 2)
            {             
                txt = hex.Substring(xtel, 2);
                hexhold = System.Convert.ToUInt32(txt, 16);
                conv[ytel] = System.Convert.ToByte(hexhold);
                ytel++;
            }           
           
            return conv;
        }

  public static string tdes_dec(string strToDecrypt)
        {
            byte[] keyz = System.Text.Encoding.ASCII.GetBytes(key);
            byte[] ivz = System.Text.Encoding.ASCII.GetBytes(iv);
            byte[] data = Hex2Bin(strToDecrypt);
            byte[] enc = new byte[0];           
            //string rstr;
            System.Security.Cryptography.TripleDES tdes = System.Security.Cryptography.TripleDES.Create();
           
            tdes.IV = ivz;
            tdes.Key = keyz;       
            tdes.Mode = System.Security.Cryptography.CipherMode.CBC;
            tdes.Padding = System.Security.Cryptography.PaddingMode.Zeros;
            System.Security.Cryptography.ICryptoTransform ict = tdes.CreateDecryptor();
            //enc = ict.TransformFinalBlock(data, 0, data.Length);
           
            return System.Text.Encoding.ASCII.GetString(enc);
        }

nogen der ved hvorfor?
Avatar billede arne_v Ekspert
29. januar 2007 - 16:55 #1
prøv og ret:

byte[] conv=new byte[(hex.Length/2)+1];

til:

byte[] conv=new byte[((hex.Length-1)/2)+1];
Avatar billede thomaxz Nybegynder
30. januar 2007 - 09:58 #2
hmm. tak, jeg havde sagt +1 fordi den før sagde indexoutofbounds.

men nu virker det i hvertfaldt, tak. læg et svar hvis du vil have points.

jeg har deusden også et andet problem, omkring brug af asykront modtaget data.

http://www.eksperten.dk/spm/759326
Avatar billede arne_v Ekspert
30. januar 2007 - 15:25 #3
svar
Avatar billede Ny bruger Nybegynder

Din løsning...

Tilladte BB-code-tags: [b]fed[/b] [i]kursiv[/i] [u]understreget[/u] Web- og emailadresser omdannes automatisk til links. Der sættes "nofollow" på alle links.

Loading billede Opret Preview
Kategori
IT-kurser om Microsoft 365, sikkerhed, personlig vækst, udvikling, digital markedsføring, grafisk design, SAP og forretningsanalyse.

Log ind eller opret profil

Hov!

For at kunne deltage på Computerworld Eksperten skal du være logget ind.

Det er heldigvis nemt at oprette en bruger: Det tager to minutter og du kan vælge at bruge enten e-mail, Facebook eller Google som login.

Du kan også logge ind via nedenstående tjenester