Calcul du Hash des fichiers chez Secure Exchanges
Chez Secure Exchanges, nous utilisons une méthode robuste et efficace pour calculer le hash SHA-512 de fichiers de toutes tailles. Notre approche assure la sécurité et l'intégrité des données tout en optimisant les performances pour les fichiers volumineux.
Méthode de Calcul du Hash
Fichiers de 1 Go ou moins :
- Pour les fichiers de taille égale ou inférieure à 1 Go, nous utilisons une méthode standard de calcul du hash SHA-512 en une seule passe sur l'ensemble du fichier.
Fichiers de plus de 1 Go :
- Pour les fichiers de taille supérieure à 1 Go, nous divisons le fichier en blocs de 100 MB.
- Nous calculons le hash SHA-512 de chaque bloc individuellement.
- Nous combinons les hashes de chaque bloc en une seule chaîne.
- Nous calculons le hash final de cette chaîne combinée.
Consultation en Ligne
Pour offrir à nos utilisateurs une flexibilité maximale, quiconque détient un fichier peut également consulter notre page dédiée pour calculer le hash de leur fichier : Calculateur de Hash. Ce service est conçu pour fournir un calcul rapide et fiable du hash, quel que soit la taille du fichier.
À partir du 24 juin 2024, nous avons mis en œuvre cette nouvelle méthode de calcul du hash pour améliorer les performances et la gestion des fichiers volumineux. Avant cette date, le hash était calculé de manière traditionnelle. Cette mise à jour reflète notre engagement continu à optimiser nos services pour répondre aux besoins de nos utilisateurs.
Chez Secure Exchanges, nous nous engageons à fournir des solutions sécurisées et performantes pour tous vos besoins de gestion de fichiers.
Exemple de Code
Voici des exemples de code en C#, JavaScript pour calculer le hash SHA-512 d'un fichier en utilisant notre approche.
c#
using System;
using System.Collections.Generic;
using System.IO;
using System.Security.Cryptography;
using System.Text;
- public static class Hashing
- {
- public static string GetSHA512OfFile(string filePath)
- {
- if (File.Exists(filePath))
- {
- const int chunkSize = 100 * 1024 * 1024; // 100 MB
- const long largeFileTrigger = 1000 * 1024 * 1024; // 1 GB
- FileInfo fileInfo = new FileInfo(filePath);
- long fileSize = fileInfo.Length;
- if (fileSize <= largeFileTrigger)
- {
- // For files smaller than or equal to 1 GB, calculate hash directly
- using (var stream = new BufferedStream(File.OpenRead(filePath), chunkSize))
- {
- return GetSHA512OfStream(stream);
- }
- }
- else
- {
- // For files larger than 1 GB, use chunked approach
- List<string> blockHashes = new List<string>();
- using (var stream = new BufferedStream(File.OpenRead(filePath), chunkSize))
- {
- byte[] buffer = new byte[chunkSize];
- int bytesRead;
- while ((bytesRead = stream.Read(buffer, 0, chunkSize)) > 0)
- {
- using (SHA512 sha512 = SHA512.Create())
- {
- byte[] chunkHash = sha512.ComputeHash(buffer, 0, bytesRead);
- blockHashes.Add(BitConverter.ToString(chunkHash).Replace("-", "").ToLower());
- }
- }
- }
- // Combine block hashes and calculate final hash
- string combinedHashString = string.Join("", blockHashes);
- using (SHA512 sha512 = SHA512.Create())
- {
- byte[] finalHash = sha512.ComputeHash(Encoding.UTF8.GetBytes(combinedHashString));
- return BitConverter.ToString(finalHash).Replace("-", "").ToUpper();
- }
- }
- }
- else
- {
- return null;
- }
- }
- public static string GetSHA512OfStream(Stream stream)
- {
- using (var sha = SHA512.Create())
- {
- return GetHexaString(sha.ComputeHash(stream));
- }
- }
- private static string GetHexaString(byte[] hash)
- {
- if (hash != null)
- {
- StringBuilder sb = new StringBuilder();
- for (int i = 0; i < hash.Length; i++)
- {
- sb.Append(hash[i].ToString("X2"));
- }
- return sb.ToString();
- }
- return string.Empty;
}
}
Javascript
- var window = self;
- var document = {};
- onmessage = async function (args) {
- var obj = args.data;
- let reader = new FileReader();
- var hash = {};
- var chunkSize = 100 * 1024 * 1024; // 100MB chunk size for large files
- var largeFileTrigger = 1000 * 1024 * 1024; // 1GB file will use block approach
- var isLargeFile = obj.File.size > largeFileTrigger;
- const chunksQuantity = Math.ceil(obj.File.size / chunkSize);
- const chunksQueue = new Array(chunksQuantity).fill().map((_, index) => index).reverse();
- let blockHashes = [];
- reader.onload = async function (evt) {
- if (isLargeFile) {
- let blockHash = await digestMessage(evt.currentTarget.result);
- blockHashes.push(blockHash);
- } else {
- blockHashes.push(evt.currentTarget.result);
- }
- readNext();
- }
- let readNext = async function () {
- if (chunksQueue.length > 0) {
- const chunkId = chunksQueue.pop();
- const sentSize = chunkId * chunkSize;
- const chunk = obj.File.slice(sentSize, sentSize + chunkSize);
- reader.readAsArrayBuffer(chunk);
- } else {
- reader.abort();
- var hexHash = null;
- if (isLargeFile) {
- let combinedHashBuffer = new TextEncoder().encode(blockHashes.join(''));
- hexHash = await digestMessage(combinedHashBuffer);
- } else {
- hexHash = await digestMessage(blockHashes[0]);
- }
- hash.SHA512 = hexHash.toUpperCase();
- postMessage({ Hash: hash, File: obj.File, ID: obj.ID, ReturnObject: obj.ReturnObject });
- }
- }
- readNext();
- }
- // Function to digest message and return hex string
- async function digestMessage(buffer) {
- const hashBuffer = await crypto.subtle.digest('SHA-512', buffer);
- const hashArray = Array.from(new Uint8Array(hashBuffer));
- const hashHex = hashArray.map(b => b.toString(16).padStart(2, '0')).join('');
- return hashHex;
- }
Related Articles
Installation du nouveau certificat SSL de Secure Exchanges - Administrateur
Si vous avez une autre procédure, vous pouvez bien sûr l'utiliser. Le script que nous proposons est simplement une aide pour simplifier le processus. L'important, c'est de vous s'assurer que notre nouveau certificat soit bien ajouté dans ...
L'Analyse de Vulnérabilité de Secure Exchanges
Secure Exchanges offre une fonctionnalité d'analyse de vulnérabilité pour aider à détecter des échanges contenant des informations potentiellement vulnérables et à risque d'être compromises. Voici un guide étape par étape pour utiliser cette fonction ...
Quels sont les paramètres de configuration de Secure Exchanges sur Gmail?
Pour configurer les paramètres de Secure Exchanges sur Gmail, vous devez cliquer sur l'extension Secure Exchanges puis sur Paramètres. Vous verrez donc apparaître la fenêtre suivante incluant diverses options: Vous pouvez ainsi définir les options ...
Comment conserver les fichiers cryptés ?
Pour que SESAR conserve vos fichiers chiffrés sur disque, vous devez générer une nouvelle clé publique/privée. Conservez la clé privée en lieu sûr et partagez avec l’équipe de Secure Exchanges votre clé publique. (pour utiliser SESAR restore vous ...
Quels sont les paramètres de configuration de Secure Exchanges sur Outlook?
Divers paramètres Secure Exchanges peuvent être configurés sur Outlook : 1. Paramètres de message : Sur ce volet, vous pouvez définir les options d'envoi et de réception de vos courriels sécurisés, la langue de votre connecteur et de communication, ...