20230904
This commit is contained in:
@@ -1,6 +1,5 @@
|
||||
using System.Text;
|
||||
|
||||
using gfoidl.Base64;
|
||||
using System.Security.Cryptography;
|
||||
using System.Text;
|
||||
|
||||
namespace anbs_cp.Classes.Encrypt;
|
||||
|
||||
@@ -10,42 +9,112 @@ namespace anbs_cp.Classes.Encrypt;
|
||||
public static class StringEncrypt
|
||||
{
|
||||
/// <summary>
|
||||
/// Метод для шифрования строки <paramref name="text"/>
|
||||
/// Получение ключа из строки
|
||||
/// </summary>
|
||||
/// <param name="text">Строка, которая должна быть зашифрована</param>
|
||||
/// <returns>Этот статический метод возвращает зашифрованную строку <paramref name="text"/></returns>
|
||||
public static string Encrypt (string text)
|
||||
/// <param name="s">Ключ-строка</param>
|
||||
/// <param name="salt">Хэш-ключ</param>
|
||||
/// <returns>Ключ</returns>
|
||||
private static byte[] KeyFromString (string s, byte[] salt)
|
||||
{
|
||||
byte[] byteText = Encoding.UTF8.GetBytes(text);
|
||||
return Base64.Url.Encode(byteText);
|
||||
// Создаю хэшер
|
||||
using Rfc2898DeriveBytes hasher = new(s, salt, 1000, HashAlgorithmName.SHA256);
|
||||
|
||||
// Получаю ключ
|
||||
return hasher.GetBytes(32);
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// Метод для шифрования массива строк <paramref name="bytes"/>
|
||||
/// Метод для шифрования строки <paramref name="text"/>
|
||||
/// </summary>
|
||||
/// <param name="bytes">Массив строк</param>
|
||||
/// <returns>Этот статический метод возвращает зашифрованную строку из массива <paramref name="bytes"/></returns>
|
||||
public static string EncryptBytes (byte[] bytes) => Base64.Url.Encode(bytes);
|
||||
/// <param name="text">Строка, которая должна быть зашифрована</param>
|
||||
/// <param name="key">Ключ</param>
|
||||
/// <returns>Этот статический метод возвращает зашифрованную строку <paramref name="text"/></returns>
|
||||
public static string Encrypt (string text, string key)
|
||||
{
|
||||
// Создаю криптограф
|
||||
using Aes aes = Aes.Create();
|
||||
|
||||
// Получаю ключ
|
||||
aes.Key = KeyFromString(key, aes.IV);
|
||||
|
||||
// Открываю поток
|
||||
using MemoryStream ms = new();
|
||||
|
||||
// Пишу данные в поток
|
||||
ms.Write(aes.IV);
|
||||
|
||||
// Создаю шифрованный поток
|
||||
using (CryptoStream cs = new(ms, aes.CreateEncryptor(), CryptoStreamMode.Write, true))
|
||||
// Пишу данные в него
|
||||
cs.Write(Encoding.UTF8.GetBytes(text));
|
||||
|
||||
// Возвращаю зашифрованный текст
|
||||
return Convert.ToBase64String(ms.ToArray());
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// Метод для дешифрования строки <paramref name="text"/>
|
||||
/// </summary>
|
||||
/// <param name="text">Строка, которая должна быть дешифрована</param>
|
||||
/// <param name="key">Ключ</param>
|
||||
/// <returns>Этот статический метод возвращает дешифрованную строку <paramref name="text"/></returns>
|
||||
public static string Decrypt (string text)
|
||||
public static string Decrypt (string text, string key)
|
||||
{
|
||||
string guidBase64Url = text.Replace('+', '-').Replace('/', '_').TrimEnd('=');
|
||||
return Encoding.UTF8.GetString(Base64.Url.Decode(guidBase64Url));
|
||||
// Открываю поток в памяти
|
||||
using MemoryStream ms = new(Convert.FromBase64String(text));
|
||||
|
||||
// Задаю ключ
|
||||
byte[] iv = new byte[16];
|
||||
|
||||
// Читаю его
|
||||
_ = ms.Read(iv);
|
||||
|
||||
// Создаю криптограф
|
||||
using Aes aes = Aes.Create();
|
||||
|
||||
// Получаю ключ
|
||||
aes.Key = KeyFromString(key, iv);
|
||||
|
||||
// присваиваю ключ
|
||||
aes.IV = iv;
|
||||
|
||||
// Создаю поток дешифратора
|
||||
using CryptoStream cs = new(ms, aes.CreateDecryptor(), CryptoStreamMode.Read, true);
|
||||
|
||||
// Задаю поток итогового текста
|
||||
using MemoryStream output = new();
|
||||
|
||||
// Копирую данные в выходной поток
|
||||
cs.CopyTo(output);
|
||||
|
||||
// Вывожу расшифрованный текст
|
||||
return Encoding.UTF8.GetString(output.ToArray());
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// Метод для дешифрования в массив byte
|
||||
/// Декодирует зашифрованную строку в HTML-пригодный формат
|
||||
/// </summary>
|
||||
/// <param name="text">Строка, которая должна быть дешифрована</param>
|
||||
/// <returns>Этот статический метод возвращает дешифрованный массива byte[]</returns>
|
||||
public static byte[] DecryptBytes (string text)
|
||||
/// <param name="text">Зашифрованная строка</param>
|
||||
/// <returns>Этот статический метод возвращает дешифрованную строку <paramref name="text"/></returns>
|
||||
public static string Base64UrlEncode(string text) => text.TrimEnd('=').Replace('+', '-').Replace('/', '_');
|
||||
|
||||
/// <summary>
|
||||
/// Раскодирует из декодированной строки в HTML-пригодный формат
|
||||
/// </summary>
|
||||
/// <param name="text">Декодированная строка</param>
|
||||
/// <returns>Этот статический метод возвращает шифрованную строку <paramref name="text"/></returns>
|
||||
public static string Base64UrlDecode(string text)
|
||||
{
|
||||
string guidBase64Url = text.Replace('+', '-').Replace('/', '_').TrimEnd('=');
|
||||
return Base64.Url.Decode(guidBase64Url);
|
||||
string result = text.Replace('_', '/').Replace('-', '+');
|
||||
switch (result.Length % 4)
|
||||
{
|
||||
case 2:
|
||||
result += "==";
|
||||
break;
|
||||
case 3:
|
||||
result += "=";
|
||||
break;
|
||||
}
|
||||
return result;
|
||||
}
|
||||
}
|
@@ -1,12 +0,0 @@
|
||||
namespace anbs_cp.Interfaces;
|
||||
|
||||
/// <summary>
|
||||
/// Интерфейс ключа
|
||||
/// </summary>
|
||||
public interface IEncryptKey
|
||||
{
|
||||
/// <summary>
|
||||
/// Ключ
|
||||
/// </summary>
|
||||
public byte[] Key { get; set; }
|
||||
}
|
@@ -2,7 +2,7 @@
|
||||
|
||||
<PropertyGroup>
|
||||
<TargetFramework>net7.0</TargetFramework>
|
||||
<Version>2023.827.0</Version>
|
||||
<Version>2023.902.0</Version>
|
||||
<Authors>Александр Бабаев</Authors>
|
||||
<Product>Набор компонентов ANB Software</Product>
|
||||
<Description>Библиотека полезных методов языка C#</Description>
|
||||
|
Reference in New Issue
Block a user