Files hash Calculation at Secure Exchanges

Files hash Calculation at Secure Exchanges

At Secure Exchanges, we use a robust and efficient method to calculate the SHA-512 hash of files of all sizes. Our approach ensures the security and integrity of the data while optimizing performance for large files.

Hash Calculation Method

  1. Files of 1 GB or less:

    • For files of 1 GB or less, we use a standard method to calculate the SHA-512 hash in a single pass over the entire file.
  2. Files larger than 1 GB:

    • For files larger than 1 GB, we divide the file into 100 MB chunks.
    • We calculate the SHA-512 hash of each chunk individually.
    • We combine the hashes of each chunk into a single string.
    • We then calculate the final hash of this combined string.

Online Consultation

To provide our users with maximum flexibility, anyone with a file can also visit our dedicated page to calculate the hash of their file: Hash Calculator. This service is designed to provide a quick and reliable hash calculation, regardless of the file size.

Info
As of June 24, 2024, we have implemented this new hash calculation method to improve performance and manage large files more efficiently. Before this date, the hash was calculated in the traditional way. This update reflects our ongoing commitment to optimizing our services to meet the needs of our users.

At Secure Exchanges, we are committed to providing secure and high-performance solutions for all your file management needs.

Code sample

Here are examples of code in C# and JavaScript to calculate the SHA-512 hash of a file using our approach.

c#
  1. using System;
  2. using System.Collections.Generic;
  3. using System.IO;
  4. using System.Security.Cryptography;
  5. using System.Text;

  6. public static class Hashing
  7. {
  8.     public static string GetSHA512OfFile(string filePath)
  9.     {
  10.         if (File.Exists(filePath))
  11.         {
  12.             const int chunkSize = 100 * 1024 * 1024; // 100 MB
  13.             const long largeFileTrigger = 1000 * 1024 * 1024; // 1 GB
  14.             FileInfo fileInfo = new FileInfo(filePath);
  15.             long fileSize = fileInfo.Length;

  16.             if (fileSize <= largeFileTrigger)
  17.             {
  18.                 // For files smaller than or equal to 1 GB, calculate hash directly
  19.                 using (var stream = new BufferedStream(File.OpenRead(filePath), chunkSize))
  20.                 {
  21.                     return GetSHA512OfStream(stream);
  22.                 }
  23.             }
  24.             else
  25.             {
  26.                 // For files larger than 1 GB, use chunked approach
  27.                 List<string> blockHashes = new List<string>();
  28.                 using (var stream = new BufferedStream(File.OpenRead(filePath), chunkSize))
  29.                 {
  30.                     byte[] buffer = new byte[chunkSize];
  31.                     int bytesRead;
  32.                     while ((bytesRead = stream.Read(buffer, 0, chunkSize)) > 0)
  33.                     {
  34.                         using (SHA512 sha512 = SHA512.Create())
  35.                         {
  36.                             byte[] chunkHash = sha512.ComputeHash(buffer, 0, bytesRead);
  37.                             blockHashes.Add(BitConverter.ToString(chunkHash).Replace("-", "").ToLower());
  38.                         }
  39.                     }
  40.                 }
  41.                 // Combine block hashes and calculate final hash
  42.                 string combinedHashString = string.Join("", blockHashes);
  43.                 using (SHA512 sha512 = SHA512.Create())
  44.                 {
  45.                     byte[] finalHash = sha512.ComputeHash(Encoding.UTF8.GetBytes(combinedHashString));
  46.                     return BitConverter.ToString(finalHash).Replace("-", "").ToUpper();
  47.                 }
  48.             }
  49.         }
  50.         else
  51.         {
  52.             return null;
  53.         }
  54.     }

  55.     public static string GetSHA512OfStream(Stream stream)
  56.     {
  57.         using (var sha = SHA512.Create())
  58.         {
  59.             return GetHexaString(sha.ComputeHash(stream));
  60.         }
  61.     }

  62.     private static string GetHexaString(byte[] hash)
  63.     {
  64.         if (hash != null)
  65.         {
  66.             StringBuilder sb = new StringBuilder();
  67.             for (int i = 0; i < hash.Length; i++)
  68.             {
  69.                 sb.Append(hash[i].ToString("X2"));
  70.             }
  71.             return sb.ToString();
  72.         }
  73.         return string.Empty;
        }
    }

Javascript

Quote
  1. var window = self;
  2. var document = {};

  3. onmessage = async function (args) {
  4.     var obj = args.data;
  5.     let reader = new FileReader();
  6.     var hash = {};
  7.     var chunkSize = 100 * 1024 * 1024; // 100MB chunk size for large files
  8.     var largeFileTrigger = 1000 * 1024 * 1024; // 1GB file will use block approach
  9.     var isLargeFile = obj.File.size > largeFileTrigger;

  10.     const chunksQuantity = Math.ceil(obj.File.size / chunkSize);
  11.     const chunksQueue = new Array(chunksQuantity).fill().map((_, index) => index).reverse();

  12.     let blockHashes = [];

  13.     reader.onload = async function (evt) {
  14.         if (isLargeFile) {
  15.             let blockHash = await digestMessage(evt.currentTarget.result);
  16.             blockHashes.push(blockHash);
  17.         } else {
  18.             blockHashes.push(evt.currentTarget.result);
  19.         }
  20.         readNext();
  21.     }

  22.     let readNext = async function () {
  23.         if (chunksQueue.length > 0) {
  24.             const chunkId = chunksQueue.pop();
  25.             const sentSize = chunkId * chunkSize;
  26.             const chunk = obj.File.slice(sentSize, sentSize + chunkSize);
  27.             reader.readAsArrayBuffer(chunk);
  28.         } else {
  29.             reader.abort();
  30.             var hexHash = null;
  31.             if (isLargeFile) {
  32.                 let combinedHashBuffer = new TextEncoder().encode(blockHashes.join(''));
  33.                 hexHash = await digestMessage(combinedHashBuffer);
  34.             } else {
  35.                 hexHash = await digestMessage(blockHashes[0]);
  36.             }

  37.             hash.SHA512 = hexHash.toUpperCase();
  38.             postMessage({ Hash: hash, File: obj.File, ID: obj.ID, ReturnObject: obj.ReturnObject });
  39.         }
  40.     }

  41.     readNext();
  42. }

  43. // Function to digest message and return hex string
  44. async function digestMessage(buffer) {
  45.     const hashBuffer = await crypto.subtle.digest('SHA-512', buffer);
  46.     const hashArray = Array.from(new Uint8Array(hashBuffer));
  47.     const hashHex = hashArray.map(b => b.toString(16).padStart(2, '0')).join('');
  48.     return hashHex;
  49. }

    • Related Articles

    • My Secure Exchanges tab is no longer present in my Outlook ribbon.

      If your Secure Exchanges tab is no longer present in your Outlook ribbon but was previously : Please follow these steps : 1. Go to Outlook, under File / Account Information / Manage COM Add-ins. 2. If the OSecureExchanges files is there, check if the ...
    • What are the configuration settings for Secure Exchanges on Gmail?

      To configure the Secure Exchanges settings on Gmail, you need to click on the Secure Exchanges extension and then on Settings. You will therefore see the following window appear with various options: You can thus define the options of the emails by ...
    • What are the Secure Exchanges configuration settings on Outlook?

      Various Secure Exchanges settings can be configured on Outlook: 1. Messages Settings : On this pane, you can define the options for sending and receiving your secure emails, the language of your connector and communication, the security and opening ...
    • Installing the new Secure Exchanges SSL certificate - Administrator

      If you have another procedure, you can certainly use it. The script we provide is simply a tool to help streamline the process. The important thing is to ensure that our new certificate is properly added to TrustedPublisher for each Secure Exchanges ...
    • How to keep encrypted files?

      In order for SESAR to keep your encrypted files on disk, you must generate a new public/private key. Keep the private key in a safe place and share your public key with the Secure Exchanges team. (to use SESAR restore you must enter your private key ...