Sample code for 30+ languages & platforms
Delphi DLL

Dropbox Content Hash

See more Dropbox Examples

Demonstrates how to compute the Dropbox content_hash of a file. (This is the "content_hash" found in the Dropbox FileMetadata object.

Note: This example requires Chilkat v9.5.0.79 or greater because it uses the fac.ReadBlockBd method.

Chilkat Delphi DLL Downloads

Delphi DLL
uses
    Winapi.Windows, Winapi.Messages, System.SysUtils, System.Variants, System.Classes, Vcl.Graphics,
    Vcl.Controls, Vcl.Forms, Vcl.Dialogs, Vcl.StdCtrls, FileAccess, BinData, Crypt2;

...

procedure TForm1.Button1Click(Sender: TObject);
var
success: Boolean;
crypt: HCkCrypt2;
fac: HCkFileAccess;
bd: HCkBinData;
bdHashes: HCkBinData;
blockSize: Integer;
numBlocks: Integer;
i: Integer;
hashHex: PWideChar;
content_hash: PWideChar;

begin
success := False;

// This example requires the Chilkat API to have been previously unlocked.
// See Global Unlock Sample for sample code.

crypt := CkCrypt2_Create();

// To calculate the content_hash of a file:
// Split the file into blocks of 4 MB (4,194,304 or 4 * 1024 * 1024 bytes). The last block (if any) may be smaller than 4 MB.
// Compute the hash of each block using SHA-256.
// Concatenate the hash of all blocks in the binary format to form a single binary string.
// Compute the hash of the concatenated string using SHA-256. Output the resulting hash in hexadecimal format.

CkCrypt2_putHashAlgorithm(crypt,'sha256');
CkCrypt2_putEncodingMode(crypt,'hex_lower');

// We're going to calculate the content_hash for the Milky Way JPG image linked here:  https://www.dropbox.com/developers/reference/content-hash

fac := CkFileAccess_Create();
bd := CkBinData_Create();
bdHashes := CkBinData_Create();

success := CkFileAccess_OpenForRead(fac,'qa_data/jpg/milky-way-nasa.jpg');
if (success = False) then
  begin
    Memo1.Lines.Add(CkFileAccess__lastErrorText(fac));
    Exit;
  end;

blockSize := 4194304;
numBlocks := CkFileAccess_GetNumBlocks(fac,blockSize);

i := 0;
while (i < numBlocks) do
  begin
    // Read the next 4MB block into bd.
    CkBinData_Clear(bd);
    success := CkFileAccess_ReadBlockBd(fac,i,blockSize,bd);

    hashHex := CkCrypt2__hashBdENC(crypt,bd);
    Memo1.Lines.Add(IntToStr(i) + ': ' + hashHex);
    CkBinData_AppendEncoded(bdHashes,hashHex,'hex_lower');

    i := i + 1;
  end;

CkFileAccess_FileClose(fac);

// Hash the concatenated SHA-256 hashes.
content_hash := CkCrypt2__hashBdENC(crypt,bdHashes);
Memo1.Lines.Add('content_hash = ' + content_hash);

CkCrypt2_Dispose(crypt);
CkFileAccess_Dispose(fac);
CkBinData_Dispose(bd);
CkBinData_Dispose(bdHashes);

end;