在我的winForm的UI中,我要求用戶輸入用戶名和密碼。我將該密碼作爲文本存儲在我的項目的Settings(.settings文件)中。該應用程序是一個視覺工作室插件.NET:在我的項目.setting文件中解密密碼有哪些選項
我怎樣才能加密和解密密碼之前和之後,我把它輸入到設置文件?
我並不需要任何幻想。這只是一個小內部應用程序。但是,我想知道我的所有選項
感謝 鮑勃
在我的winForm的UI中,我要求用戶輸入用戶名和密碼。我將該密碼作爲文本存儲在我的項目的Settings(.settings文件)中。該應用程序是一個視覺工作室插件.NET:在我的項目.setting文件中解密密碼有哪些選項
我怎樣才能加密和解密密碼之前和之後,我把它輸入到設置文件?
我並不需要任何幻想。這只是一個小內部應用程序。但是,我想知道我的所有選項
感謝 鮑勃
我這個DD吧:
public static string Decrypt(string stringToDecrypt)
{
UnicodeEncoding byteConverter = new UnicodeEncoding();
byte[] dataToEncrypt = byteConverter.GetBytes(stringToDecrypt);
byte[] decryptedData = null;
try
{
using (RSACryptoServiceProvider rsaCryptoServiceProvider = new RSACryptoServiceProvider())
{
rsaCryptoServiceProvider.FromXmlString(_key);
byte[] decryptBytes = Encoding.Default.GetBytes(Properties.Settings.Default.SqlPassword);
decryptedData = rsaCryptoServiceProvider.Decrypt(decryptBytes, false);
}
}
catch (Exception ex)
{
//TODO Do proper logging
Console.WriteLine("Decrypt failed: " + ex.Message);
}
return byteConverter.GetString(decryptedData);
}
public static string Encrypt(string stringToEncrypt)
{
try
{
UnicodeEncoding byteConverter = new UnicodeEncoding();
byte[] dataToEncrypt = byteConverter.GetBytes(stringToEncrypt);
using (RSACryptoServiceProvider rsaCryptoServiceProvider = new RSACryptoServiceProvider())
{
rsaCryptoServiceProvider.FromXmlString(_key);
byte[] encryptedData = rsaCryptoServiceProvider.Encrypt(dataToEncrypt, false);
return Encoding.Default.GetString(encryptedData);
}
}
catch (Exception ex)
{
Console.WriteLine("Encrypt failed: " + ex.Message);
}
}
使用。NET加密功能簡單的東西as in this article。
我有我自己的服務(寫在我的項目之一),你可以用我的代碼,如果你想:)你可以加密/解密的byte []和字符串
//***********************************************************************
// Assembly : Common
// Author : SERKANH
// Created : 09-27-2009
//
// Last Modified By : SERKANH
// Last Modified On : 09-27-2009
// Description :
//
// Copyright : (c) Microsoft. All rights reserved.
//***********************************************************************
using System;
using System.IO;
using System.Security.Cryptography;
using System.Text;
namespace Common
{
/// <summary>
/// This class provides 3DES encryption and decryption routines.
///
/// Serkan Hekimoglu
/// </summary>
public class TripleDes
{
readonly byte[] _key = { 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23, 24 };
readonly byte[] _iv = { 8, 7, 6, 5, 4, 3, 2, 1 };
// define the triple des provider
private readonly TripleDESCryptoServiceProvider _mDes = new TripleDESCryptoServiceProvider();
// define the string handler
private readonly UTF8Encoding _mUtf8 = new UTF8Encoding();
// define the local property arrays
private readonly byte[] _mKey;
private readonly byte[] _mIv;
/// <summary>
/// Default constructor
/// </summary>
public TripleDes()
{
_mKey = _key;
_mIv = _iv;
}
/// <summary>
/// Parameterized constructor
/// </summary>
/// <param name="key"></param>
/// <param name="iv"></param>
public TripleDes(byte[] key, byte[] iv)
{
_mKey = key;
_mIv = iv;
}
/// <summary>
/// Encrypts the given byte array input
/// </summary>
/// <param name="input">Input value</param>
/// <returns>Encrypted result</returns>
public byte[] Encrypt(byte[] input)
{
return Transform(input, _mDes.CreateEncryptor(_mKey, _mIv));
}
/// <summary>
/// Decrypts the given encrypted byte array input
/// </summary>
/// <param name="input">Encrypted byte array input</param>
/// <returns>Decrypted result</returns>
public byte[] Decrypt(byte[] input)
{
return Transform(input, _mDes.CreateDecryptor(_mKey, _mIv));
}
/// <summary>
/// Encrypts the given string input
/// </summary>
/// <param name="text">Input value</param>
/// <returns>Encrypted result</returns>
public string Encrypt(string text)
{
byte[] input = _mUtf8.GetBytes(text);
byte[] output = Transform(input, _mDes.CreateEncryptor(_mKey, _mIv));
return Convert.ToBase64String(output);
}
/// <summary>
/// Decrypts the given encrypted string input
/// </summary>
/// <param name="text">Encrypted string input</param>
/// <returns>Decrypted result</returns>
public string Decrypt(string text)
{
byte[] input = Convert.FromBase64String(text);
byte[] output = Transform(input, _mDes.CreateDecryptor(_mKey, _mIv));
return _mUtf8.GetString(output);
}
private static byte[] Transform(byte[] input, ICryptoTransform cryptoTransform)
{
// create the necessary streams
using (MemoryStream memStream = new MemoryStream())
{
using (CryptoStream cryptStream = new CryptoStream(memStream, cryptoTransform, CryptoStreamMode.Write))
{
// transform the bytes as requested
cryptStream.Write(input, 0, input.Length);
cryptStream.FlushFinalBlock();
// Read the memory stream andconvert it back into byte array
memStream.Position = 0;
byte[] result = memStream.ToArray();
// close and release the streams
memStream.Close();
cryptStream.Close();
// hand back the encrypted buffer
return result;
}
}
}
}
}
這是2003年的一篇文章。自.NET 1以來沒有任何變化? – Bob 2010-11-15 11:17:33
可能已經添加了一些高級的東西,但是因爲您正在尋找簡單的東西,所以使用這個舊的示例不會受到傷害。至少你可以試試:) – 2010-11-15 11:19:47