File hash

Hashes of uploaded files, which can be found on a variety of sites from to, allow files to be uniquely identified, allow duplicate files to be detected, and allow copies to be verified against the original source.

File hash module generates and stores MD5, SHA-1 and/or SHA-256 hashes for each file uploaded to the site.

Hash algorithms can be enabled and disabled by the site administrator.

Hash values are loaded into the File object where they are available to the theme and other modules.

Handlers are provided for Views module compatibility. In addition, a <media:hash> element is added for file attachments in node RSS feeds (file, image, and media field types are supported).

Tokens are provided for the full hashes, as well as pairtree tokens useful for content addressable storage. For example, if the MD5 hash for a file is 3998b02c5cd2723153c39701683a503b, you could store it in the files/39/98 directory using these tokens: [file:filehash-md5-pair-1]/[file:filehash-md5-pair-2]. Note, to use these tokens to configure the file upload directory, File Entity Paths module or File (Field) Paths module is required.

Optional duplicate file prevention

A checkbox in file hash settings allows duplicate uploaded files to be rejected. This feature should be considered a proof-of-concept—you may want better UX for such a feature. Note, in Drupal 7, empty files are not considered duplicate files, as such "files" may represent remote media assets, etc. In Drupal 8, if any modules allow existing file entities to be updated with a new file, the duplicate check will not be performed on the contents of the updated file (please file a bug report if this issue affects you).

Supporting organizations: 

Project Information