Skip to main content

Validating Data Integrity with Hashes using .Net

Validating Data Integrity with Hashes:
            Hashes can be used to generate code that cross pond to specific data or file. But you can’t reproduce data from the hash. All hash algorithms inherit from System.Security.Cryptography.HashAlgorithms. These algorithms include:

MD5
Represents the abstract class from which all implementations of the MD5 hash algorithm inherit.
HashSize =128
 RIPEMD160
Represents the abstract class from which all implementations of the MD160 hash algorithm inherit.
HashSize=128
SHA1
HashSize = 160 bits
SHA256
HashSize = 256 bits
SHA384
HashSize = 384 bits
SHA512
HashSize = 512 bits

Keyed Hash Algorithms:
                All Keyed Hash Algorithms inherit from System.Security.Cryptography.KeyedHashAlgorithm which in turn inherits from HashAlgorithm. These Algorithms include:

HMACSHA1: Both sender and receiver share the same secret key. It uses SHA1 to produce hash of length 20 bytes. It accepts key of all sizes.

MACTripleDES: Uses TripleDES to produce a hash of 8 bytes. It accepts key of size 8, 16, or 24 bytes.

Computing a Non-Keyed hash:

byte[] data = new byte[DATA_SIZE];
MD5 md5 = new MD5CryptoServiceProvider();
byte[] result = md5.ComputeHash(data);


Computing a Keyed Hash:

HMACSHA1 myhmacsha1 = new HMACSHA1( key );
FileStream inStream = new FileStream(sourceFile, FileMode.Open);

byte[] hashValue = myhmacsha1.ComputeHash(inStream);

myhmacsha1.Clear();

inStream.Close();

Digitally Signing Files:
Digital signature is a value that is appended to a file to secure its contents. For this purpose public key is used that is the part of the signature. The recipient receives and verifies the signature, before trusting on it. RSACryptoServiceProvider and DSACryptoServiceProvider are the two implementations for digitally signing documents. Properties involved in signing are:

SignData
Overloaded. Computes the hash value of the specified data and signs it.
SignHash
Computes the signature for the specified hash value by encrypting it with the private key.
ToXmlString 
Creates and returns an XML string containing the key of the current RSA object. (Inherited from RSA.)
VerifyData
Verifies the specified signature data by comparing it to the signature computed for the specified data.
VerifyHash
Verifies the specified signature data by comparing it to the signature computed for the specified hash value.

Comments

Popular posts from this blog

Culture Information and Localization in .NET

Namespace: System.Globalization CultureInfo Class:                 It provides information like the Format of numbers and dates, Culture’s Calendar, Culture’s language and sublanguage (if applicable), Country and region of the culture. The Basic use of CultureInfo class is shown here: • How string Comparisons are performed • How Number Comparison & Formats are performed • Date Comparison and Formats. • How resources are retrieved and used. Cultures are grouped into three categories: Invariant Culture : It’s Culture Insensitive. It can be used to build some trial application. It can be also used to build an application with hard-coded expiry date that ignores cultures. But using it for every comparison will be incorrect and inappropriate. Neutral Culture : English(en), Frensh(fr), and Spanish(sp). A neutral culture is related to language but it’s not related to specific regi...

Concept of App Domain in .Net

Creating Application Domains: Application domain is just like process, provides separate memory space, and isolates from other code. But it’s quite light weight. It also provides the following advantages: 1-       Reliability : If a domain crashes, it can be unloaded. Hence doesn’t affect the other assemblies. 2-       Efficiency : Loading all assemblies in one domain can be cumbersome and can make the process heavy but Appdomains are efficient in this manner. Important properties of AppDomain: ApplicationIdentity , ApplicationTrust , BaseDirectory , CurrentDomain , DomainManager , DomainDirectory , Evidence , FriendlyName , ID , RelativeSearchPath , SetupInformation , ShadowCopyFiles . Important methods of AppDomain: ApplyPolicy , CreateCOMInstanceFrom , CreateDomain , CreateInstance (Assembly). To create an AppDomain: AppDomain adomain = AppDomain.CreateDomain(“D”); To execute an assembly:...

Asynchronous Execution in ASP.NET

Asynchronous Execution: Two ways either implement IHTTPAsyncHandler interface or in ASP.NET 2.0 set <%@ Page Async=”true” %>. The second option implements IHTTPAsyncHandler interface automatically for the page when parsed or compiled. AddOnPreRenderCompleteAsync ( new BeginEventHandler(BeginTask), new EndEventHandler(EndTask)); AddOnPreRenderCompleteAsync() shoud be called in Page_load. The BeginEventHandler and EndEventHandler are delegates defined as follows: IAsyncResult BeginEventHandler( object sender, EventArgs e, AsyncCallback cb, object state) void EndEventHandler( IAsyncResult ar) AsyncProcess starts and completes between PreRender and PreRenderComplete. Other way to perform Async Task is using AsyncPageTask structure. It also allows multiple tasks to execute simultaneously. void Page_Load (object sender, EventArgs e) { PageAsyncTask task = new PageAsyncTask( new BeginEventHandler(BeginTask), new EndEventH...