Diskuze: Načtení a uložení hesla v Hash tvaru
V předchozím kvízu, Test znalostí C# .NET online, jsme si ověřili nabyté zkušenosti z kurzu.
Zobrazeno 5 zpráv z 5.
//= Settings::TRACKING_CODE_B ?> //= Settings::TRACKING_CODE ?>
V předchozím kvízu, Test znalostí C# .NET online, jsme si ověřili nabyté zkušenosti z kurzu.
Ahoj, nie som c sharpista, ale kým ti niekto napíše tak si môžeš vygoogliť csharp hash password a určite tam nájdeš riešenie.
A čo myslíš tým aby to fungovalo oboma smermi? Čaro hashovania hesiel je práve v tom, že je to jednosmerný proces. Čiže ak zahashuješ heslo tak z hashu nevieš späť dostať pôvodné heslo. Takže keď chceš zistiť či sa heslá zhodujú, získaš hash aj z druhého a až tie porovnáš.
To jsem už také zjistil jinde, že to je jen jednosměrný proces.
Problém ale je, že kdokoli vlastně může ze souboru textového formátu
vzít hash starého hesla a tím tak si změnit pro sebe přes nové heslo to
staré.
Takže by to chtělo asi ještě přidat nějaký ocásek, který bych znal jen
já jako autor, ale který by se nikde neuváděl, jen v kodu programu.
Asi by som musel viacej vidieť do toho čo kódiš, ale keď by aj niekto získal jednotlivé hashe hesiel a potom nejaký z nich použil pre zmenu hesla tak kód by mal byť taký, že zoberie pôvodné heslo, vytvorí hash a až ten porovná so správnym hashom. Takže ak niekto ako pôvodné heslo vloží samotný hash tak sa znova z neho vytvorí hash a ten bude iný ako ten zo správneho hesla a preto by mala zmena hesla zlyhať.
jak říká kolega, nehledej v tom složitost, vytvoříš hash pro heslo, to si ulož klidně do textového souboru, pro ověření uživatele, znovu vytváříš hash a ten porovnáváš s tím co sis uložil. něco jako :
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Windows.Forms;
using System.Security.Cryptography;
namespace HashTest
{
public partial class Form1 : Form
{
public string passHash;
public Form1()
{
InitializeComponent();
}
private void bZadej_Click(object sender, EventArgs e)
{
string passOriginal = tbText.Text;
using (SHA1 sha1Hash = SHA1.Create())
{
byte[] sourceBytes = Encoding.UTF8.GetBytes(passOriginal);
byte[] hashBytes = sha1Hash.ComputeHash(sourceBytes);
passHash = BitConverter.ToString(hashBytes).Replace("-", string.Empty);
}
}
private void bUhodni_Click(object sender, EventArgs e)
{
string passTry = tbText.Text;
using (SHA1 sha1Hash = SHA1.Create())
{
byte[] sourceBytes = Encoding.UTF8.GetBytes(passTry);
byte[] hashBytes = sha1Hash.ComputeHash(sourceBytes);
string passTryHash = BitConverter.ToString(hashBytes).Replace("-", string.Empty);
if (passHash != passTryHash)
MessageBox.Show("Špatné heslo");
else
MessageBox.Show("Dobrá práce :-)");
}
}
}
}
Zobrazeno 5 zpráv z 5.