MANGACS TEAM
All for Counter strike 1.6 and more WWW.MANGACS.3XFORUM.RO WWW.MANGACS.3XFORUM.RO WWW.MANGACS.3XFORUM.RO WWW.MANGACS.3XFORUM.RO FREE DOWNLOAD - Filme noi 2016 filme noi filme comedie filme horror filme de groaza filme aventura filme actiune filme desene animate download filme gratis filme noi , filme thriller , filme gratis , jocuri full download , jocuri gratis , jocuri full , muzica noua , muzica romaneasca , hacking , torrent , jocuri free download , free download cfg silent aim ,dll , aimbot for counter strike 1.6 free download, scripts aim , eac , voiplay , Vac : WWW.MANGACS.3XFORUM.RO WWW.MANGACS.3XFORUM.RO FREE DOWNLOAD Cheat counter strike eac3 vac3 aimbot dll yahoo facebook hack aegiss
|
Lista Forumurilor Pe Tematici
|
MANGACS TEAM | Reguli | Inregistrare | Login
POZE MANGACS TEAM
Nu sunteti logat.
|
Nou pe simpatie: sanda_21
| Femeie 22 ani Alba cauta Barbat 23 - 57 ani |
|
Hacker.hLs
Pe lista neagra
Inregistrat: acum 13 ani
Postari: 298
|
|
//Late night tutorial wannabe
Din neincredere fata de managerele de parole (password managers) existente pe net, m-ai facut eu unul personal in C#. Una dintre problemele aparute imediat a fost cum sa-mi stochez datele in baza de date astfel incat sa fie in siguranta chiar daca baza de date ajunge pe maini curioase.
Cu putin google si ceva wiki, am reusit sa-mi creez o clasa ce cripteaza si decripteaza un string intr-un mod suficient de sigur, cred eu.
Full code:
Code:
using System;
using System.Text;
using System.Security.Cryptography;
using System.Windows.Forms;
namespace KeyMemo
{
class locker
{
public locker() { }
public string Cripteaza(string mesaj, string cheie)
{
string str = "";
UTF8Encoding UTF8 = new UTF8Encoding();
//creez un convertor in md5 si un encoder TDSA
MD5CryptoServiceProvider md5 = new MD5CryptoServiceProvider();
TripleDESCryptoServiceProvider TDSA = new TripleDESCryptoServiceProvider();
try
{
// cheie => md5 hash
byte[] cheieMD5 = md5.ComputeHash(UTF8.GetBytes(cheie));
//setari pentru encoderul TDSA
TDSA.Key = cheieMD5;
TDSA.Mode = CipherMode.ECB;
TDSA.Padding = PaddingMode.PKCS7;
//criptam mesajul
ICryptoTransform crypt = TDSA.CreateEncryptor();
str = Convert.ToBase64String(crypt.TransformFinalBlock(UTF8.GetBytes(mesaj), 0, UTF8.GetBytes(mesaj).Length));
}
catch (Exception exc)
{
MessageBox.Show("A aparut o eroare: \n\n" + exc.ToString(), "Eroare!", MessageBoxButtons.OK, MessageBoxIcon.Error);
}
finally
{
md5.Clear();
TDSA.Clear();
}
return str;
}
public string Decripteaza(string cod, string cheie)
{
string str = "";
UTF8Encoding UTF8 = new UTF8Encoding();
//creez un convertor in md5 si un encoder TDSA
MD5CryptoServiceProvider md5 = new MD5CryptoServiceProvider();
TripleDESCryptoServiceProvider TDSA = new TripleDESCryptoServiceProvider();
try
{
// cheie => md5 hash
byte[] cheieMD5 = md5.ComputeHash(UTF8.GetBytes(cheie));
//setari pentru encoderul TDSA
TDSA.Key = cheieMD5;
TDSA.Mode = CipherMode.ECB;
TDSA.Padding = PaddingMode.PKCS7;
//criptam mesajul
ICryptoTransform crypt = TDSA.CreateDecryptor();
str = UTF8.GetString(crypt.TransformFinalBlock(Convert.FromBase64String(cod),0,Convert.FromBase64String(cod).Length));
}
catch (Exception exc)
{
MessageBox.Show("A aparut o eroare: \n\n" + exc.ToString(), "Eroare!", MessageBoxButtons.OK, MessageBoxIcon.Error);
}
finally
{
md5.Clear();
TDSA.Clear();
}
return str;
}
}
} |
Cum functioneaza?
Cam asa: Folosim algoritmul 3DES cu o cheie de 128 biti pentru criptare. Mai exact, trimit ca parametri stringul pe care vreau sa-l criptez si cheia (in plain text). Cheia o transform intr-un hash md5 ca sa ma asigur ca am o cheie de 128 biti
Code:
// cheie => md5 hash
byte[] cheieMD5 = md5.ComputeHash(UTF8.GetBytes(cheie)); |
Apoi aplic algoritmul (care este built-in in C#) pentru stringul meu si cheia in md5:
Code:
TripleDESCryptoServiceProvider TDSA = new TripleDESCryptoServiceProvider();
//setari pentru encoderul TDSA
TDSA.Key = cheieMD5;
TDSA.Mode = CipherMode.ECB;
TDSA.Padding = PaddingMode.PKCS7;
//criptam mesajul
ICryptoTransform crypt = TDSA.CreateEncryptor();
str = crypt.TransformFinalBlock(UTF8.GetBytes(mesaj), 0, UTF8.GetBytes(mesaj).Length); |
In final, trec stringul obtinut prin Base64 ca sa-l aduc la o forma adecvata pentru stocarea in baza de date:
Code:
str = Convert.ToBase64String(crypt.TransformFinalBlock(UTF8.GetBytes(mesaj), 0, UTF8.GetBytes(mesaj).Length)); |
Criptarea obtinuta are formula Base64(3DSA(textInitial,MD5(Cheie))). Pare a fi suficient de complicat si de ambiguu pentru a putea dormi linistit, dar mi-am mai luat o masura de precautie in program: cheia folosita pentru criptare este parola de logare in program. Parola este retinuta in baza de date ca fiind Base64( 3DSA (Parola,MD5(Parola)), deci nu poate fi decriptata, astfel logarea in program se va face pe baza compararii stringului din baza de date cu criptarea parolei introduse de utilizator. Daca cele doua se potrivesc, atunci retinem parola in program.
Restul datelor criptate au cheia parola de mai sus (care se presupune a fi stiuta doar de cel care se autentifica in program), deci criptarea este sigura.
Decriptarea decurge asemanator: - parametri: string in Base64, parola in plain text; - parola => MD5(parola) - se decodeaza stringul din base64 - se decripteaza textul folosind stringul de la pasul anterior si cheia din md5.
Asadar, parolele din baza de date pot fi decriptate doar dupa ce utilizatorul a introdus de la tastatura parola. Pare a fi o metoda de criptare buna, zic eu. Ce parere aveti?
Daca vreti si voi managerul de parole, dati un PM. In versiunea actuala are ceva din tema de culori RST (negru cu verde), suport pentru mai mai multe persoane (utilizatori diferiti), Adaugari de conturi, sortari, cautari dupa cateva criterii, editari de conturi, validari pe campuri in timp real, tab index corect, tasta Enter face cam ce ar trebui sa faca... Nu l-am testat decat pe win7 x86, rezolutie 1680x1050, deci ar putea aparea probleme de incompatibilitate (desi i-am facut si installer). Printuri: Omuletul KeyMemo by hLs
Modificat de Hacker.hLs (acum 12 ani)
|
|
pus acum 12 ani |
|