Sample code for 30+ languages & platforms
Java

Password_Digest = Base64 (SHA-1 ( nonce + created + SHA-1 (password) ) )

See more Encryption Examples

Demonstrates how to compute:
Password_Digest = Base64 (SHA-1 ( nonce + created + SHA-1 (password)))

Chilkat Java Downloads

Java
import com.chilkatsoft.*;

public class ChilkatExample {

  static {
    try {
        System.loadLibrary("chilkat");
    } catch (UnsatisfiedLinkError e) {
      System.err.println("Native code library failed to load.\n" + e);
      System.exit(1);
    }
  }

  public static void main(String argv[])
  {
    // This example requires the Chilkat API to have been previously unlocked.
    // See Global Unlock Sample for sample code.

    String password = "secret";

    CkCrypt2 crypt = new CkCrypt2();
    crypt.put_HashAlgorithm("SHA-1");
    crypt.put_EncodingMode("base64");

    // Generate a 16-byte random nonce
    CkPrng prng = new CkPrng();
    CkBinData bd = new CkBinData();
    prng.GenRandomBd(16,bd);

    // Get the current date/time in a string with this format: 2010-06-08T07:26:50Z
    CkDateTime dt = new CkDateTime();
    dt.SetFromCurrentSystemTime();
    String created = dt.getAsTimestamp(false);
    bd.AppendString(created,"utf-8");

    // This example wishes to calculate a password digest like this:
    // Password_Digest = Base64 ( SHA-1 ( nonce + created + SHA-1(password) ) )

    // First SHA-1 digest the password...
    String passwordSha1 = crypt.hashStringENC(password);
    // Append the 20 binary bytes of the SHA1 hash to bd, which already contains the nonce and created date/time.
    bd.AppendEncoded(passwordSha1,"base64");

    String passwordDigest = crypt.hashBdENC(bd);

    System.out.println("Base64 password digest = " + passwordDigest);
  }
}