[Okta Webinar] Learn how to a build a cloud-first strategyRegister Now

x
  • Status: Solved
  • Priority: Medium
  • Security: Public
  • Views: 518
  • Last Modified:

C# secure / uncesure string

I need in C# 2008 NET 2.0 simple static class  which secure / unsecure string which will be saved in text file. Will be good to be with some key, mean that with different kay to provide different secure string.

Greeting !
0
dvplayltd
Asked:
dvplayltd
  • 6
  • 2
  • 2
1 Solution
 
MarkMyburghCommented:
HI
query: what do yo mean secure string?  do you have a string encripyted?
you could do something like

var Dic = new Dictionary<string, string>)()

dictionary.Add("Secure", "some string");
dictionary.Add("Unsecure", "some string");
0
 
dvplayltdAuthor Commented:
Hi !

 I need class that do function crypt/ decrypt string which will be saved in text file.
0
 
MarkMyburghCommented:
you could try implementing something like this
class test
{
    enum StringType
	{
        Encrypt,
        Decrypt	         
	}
 
    private static string MyString { get; set; }
 
    static string GetString(StringType type)
    {
 
        switch (type)
       {
            case StringType.Decrypt: MyString = DoDecrypt(); break;
            case StringType.Encrypt: MyString = DoEncrypt(); break;
        }
        return MyString;
    }
  
}

Open in new window

0
Transaction-level recovery for Oracle database

Veeam Explore for Oracle delivers low RTOs and RPOs with agentless transaction log backup and transaction-level recovery of Oracle databases. You can restore the database to a precise point in time, even to a specific transaction.

 
MarkMyburghCommented:
or if you want to store mutliple strings
 

class test
{
    enum StringType
	{
        Encrypt,
        Decrypt	         
	}
 
    static private Dictionary<string, StringStruc> MyString { get; set; }
    
    static string GetString(string key, StringType type)
    {
 
        switch (type)
       {
            case StringType.Decrypt: 
                {
                    if (MyString[key].Encrypted)
                    {
                        MyString[key].MyString = DoDecrypt();
                    }                    
                }
            case StringType.Encrypt:
                {
                    if (!MyString[key].Encrypted)
                    {
                        MyString[key].MyString = DoEncrypt();
                    }
                }
        }
        return MyString;
    }
  
}
 
struct StringStruc
{
    public string MyString { get; set; }
    public bool Encrypted { get; set; }
}

Open in new window

0
 
MarkMyburghCommented:
sorry replace
         return MyString;

with

return MyString[key].MyString;
0
 
MarkMyburghCommented:
its been a long day!
forgot to set the flag to true or false if the string has been encrtyped or not

class test
{
    enum StringType
    {
        Encrypt,
        Decrypt
    }
 
    static private Dictionary<string, StringStruc> MyString { get; set; }
 
    static string GetString(string key, StringType type)
    {
 
        switch (type)
        {
            case StringType.Decrypt:
                {
                    if (MyString[key].Encrypted)
                    {
                        MyString[key].MyString = DoDecrypt();
                        MyString[key].Encrypted = false;
                    }
                }
            case StringType.Encrypt:
                {
                    if (!MyString[key].Encrypted)
                    {
                        MyString[key].MyString = DoEncrypt();
                        MyString[key].Encrypted = true;
                    }
                }
        }
        return MyString[key].MyString; 
    }
 
}
 
struct StringStruc
{
    public string MyString { get; set; }
    public bool Encrypted { get; set; }
}

Open in new window

0
 
Mike TomlinsonMiddle School Assistant TeacherCommented:
You first need to determine whether you need actual ENCRYPTION or a HASH.

(1) Encryption: The value is encoded with a key and stored somewhere.  Then you can retrieve the encoded value, decode it with the key, and you end up with the original value.  This is a TWO WAY system, otherwise known as a symmetric algorithm.  A credit card number would need encryption since you need the actual value to purchase something.  If the "key" is compromised then the data is compromised.

(2) Hashing: The value is "hashed" and converted it to a fixed length value using a hashing algorithm.  Different hash algorithms produce different lengths of hashes.  Then you store the hash somewhere.  Now you can determine if a value entered by the user is the same as the original value by comparing the hashes.  You hash the current value and see if that hash matches the original hash.  A hash is a ONE WAY system.  You CANNOT get the original value back from the hash.  Passwords are often stored as Hashes since you can't figure out what the original value was from looking at the hash.  There is no "key" that can be compromised with hashing.

0
 
dvplayltdAuthor Commented:
Encryption is good enough. I will test you example soon. I hope that is full - I mean that with copy/paste will work . IN first look - I don't see code for function DoEncrypt() and DoDecrypt() ?
0
 
Mike TomlinsonMiddle School Assistant TeacherCommented:
0
 
MarkMyburghCommented:
Hi dvplay:td
Did not have time at work to implement the encryption stuff.  have a look at the msdn link above.
else i'll try to smack something together tomorrow for you
0

Featured Post

NFR key for Veeam Agent for Linux

Veeam is happy to provide a free NFR license for one year.  It allows for the non‑production use and valid for five workstations and two servers. Veeam Agent for Linux is a simple backup tool for your Linux installations, both on‑premises and in the public cloud.

  • 6
  • 2
  • 2
Tackle projects and never again get stuck behind a technical roadblock.
Join Now