Calculer le Checksum d’un ‘tempon’

Author:

Exemple,d'utilisation,de,'PermissionSet'
{filelink=17829}

// crudwork
// Copyright 2004 by Steve T. Pham (http://www.crudwork.com)
//
// This program is free software: you can redistribute it and/or modify
// it under the terms of the GNU General Public License as published by
// the Free Software Foundation, either version 3 of the License, or
// (at your option) any later version.
//
// This program is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
// GNU General Public License for more details.
//
// You should have received a copy of the GNU General Public License
// along with This program.  If not, see .

using System;
using System.Text;
using System.IO;

namespace MesExemples.Securités
{

  public static class MathUtil
  {

	// Calculer le Checksum de 'buffer' passé en paramètre
    public static long ComputeChecksum(byte[] buffer)
    {
      return ComputeChecksum(buffer, 0);
    }

	// Calculer le checksum de 'buffer' passé en paramètre à partr de l'index 'décalage'
    public static long ComputeChecksum(byte[] buffer, int décalage)
    {
      long sum = 0;
      for (int i = 0; i < buffer.Length; i++)
      {
        sum += buffer[i] * (i + 1 + décalage);
      }
      return sum;
    }

	// Calculer le checksum d'un fichier
    public static long ComputeChecksum(string nomFichier)
    {

      long sum = 0;
      int bufSize = 4096;

      using (FileStream fs = new FileStream(nomFichier, FileMode.Open, FileAccess.Read))
      using (BinaryReader r = new BinaryReader(fs))
      {
        byte[] readChar = null;
        int décalage = 0;

        do
        {
		 // Lire les caractères
          readChar = r.ReadBytes(bufSize);
          sum += ComputeChecksum(readChar, décalage);
          décalage += readChar.Length;
        } while ((readChar != null) && (readChar.Length > 0));

        r.Close();
      }

      return sum;
    }
  }
}

Leave a Reply

Your email address will not be published. Required fields are marked *