Google

Checksum

Description

Generates checksum for files. This task can also be used to perform checksum verifications.

Parameters

Attribute Description Required
file The file to generate checksum for. One of either file or at least one nested fileset element.
algorithm Specifies the algorithm to be used to compute the checksum. Defaults to "MD5". Other popular algorithms like "SHA" may be used as well. No
provider Specifies the provider of the algorithm. No
fileext The generated checksum file's name will be the original filename with "." and fileext added to it. Defaults to the algorithm name being used. No
property Specifies the name of the property to be set with the generated checksum value. This cannot be specified when fileext is being used or when the number of files for which checksums is to be generated is greater than 1. No
forceoverwrite Overwrite existing files even if the destination files are newer. Defaults to "no". No
verifyproperty Specifies the name of the property to be set with "true" or "false" depending upon whether the generated checksum matches the existing checksum. When this is set, the generated checksum is not written to a file or property, but rather, the content of the file or property is used to check against the generated checksum. No
readbuffersize The size of the buffer )in bytes) to use when reading a file. Defaults to "8192" - you may get a better performance on big files if you increase this value. No

Parameters specified as nested elements

fileset

FileSets are used to select files to generate checksums for.

Examples

Example 1

<checksum file="foo.bar"/>
Generates a MD5 checksum for foo.bar and stores the checksum in the destination file foo.bar.MD5. foo.bar.MD5 is overwritten only if foo.bar is newer than itself.

Example 2

<checksum file="foo.bar" forceOverwrite="yes"/>
Generates a MD5 checksum for foo.bar and stores the checksum in foo.bar.MD5. If foo.bar.MD5 already exists, it is overwritten.

Example 3

<checksum file="foo.bar" property="foobarMD5"/>
Generates a MD5 checksum for foo.bar and stores it in the Project Property foobarMD5.

Example 4

<checksum file="foo.bar" verifyProperty="isMD5ok"/>
Generates a MD5 checksum for foo.bar, compares it against foo.bar.MD5 and sets isMD5ok to either true or false, depending upon the result.

Example 5

<checksum file="foo.bar" algorithm="SHA" fileext="asc"/>
Generates a SHA checksum for foo.bar and stores the checksum in the destination file foo.bar.asc. foo.bar.asc is overwritten only if foo.bar is newer than itself.

Example 6


<checksum file="foo.bar" property="${md5}" verifyProperty="isEqual"/>

Generates a MD5 checksum for foo.bar, compares it against the value of the property md5, and sets isEqual to either true or false, depending upon the result.

Example 7


<checksum>

  <fileset dir=".">

    <include name="foo*"/>

  </fileset>

</checksum>

Works just like Example 1, but generates a .MD5 file for every file that begins with the name foo.

Example 8


<condition property="isChecksumEqual">

  <checksum>

    <fileset dir=".">

      <include name="foo.bar"/>

    </fileset>

  </checksum>

</condition>

Works like Example 4, but only sets isChecksumEqual to true, if the checksum matches - it will never be set to false. This example demonstrates use with the Condition task.

Note:

When working with more than one file, if condition and/or verifyproperty is used, the result will be true only if the checksums matched correctly for all files being considered.

Copyright © 2001-2002 Apache Software Foundation. All rights Reserved.