1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 | /* * Copyright (C) 1996 Santeri Paavolainen, Helsinki Finland * * Copyright (C) 2002-2010 Stephen Ostermiller * http://ostermiller.org/contact.pl?regarding=Java+Utilities * * 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 2 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. * * See LICENSE.txt for details. * * The original work by Santeri Paavolainen can be found a */ package com.Ostermiller.util; import java.io.*; /** * Implements MD5 functionality on a stream. * More information about this class is available from <a target="_top" href= * "http://ostermiller.org/utils/MD5.html">ostermiller.org</a>. * <p> * This class produces a 128-bit "fingerprint" or "message digest" for * all data written to this stream. * It is conjectured that it is computationally infeasible to produce * two messages having the same message digest, or to produce any * message having a given pre-specified target message digest. The MD5 * algorithm is intended for digital signature applications, where a * large file must be "compressed" in a secure manner before being * encrypted with a private (secret) key under a public-key cryptosystem * such as RSA. * <p> * For more information see RFC1321. * * @see MD5 * @see MD5InputStream * * @author Santeri Paavolainen http://santtu.iki.fi/md5/ * @author Stephen Ostermiller http://ostermiller.org/contact.pl?regarding=Java+Utilities * @since ostermillerutils 1.00.00 */ public class MD5OutputStream extends FilterOutputStream { /** * MD5 context */ private MD5 md5; /** * Creates MD5OutputStream * @param out The output stream * * @since ostermillerutils 1.00.00 */ public MD5OutputStream(OutputStream out) { super (out); md5 = new MD5(); } /** * Writes the specified byte to this output stream. * * @param b the byte. * @throws IOException if an I/O error occurs. * * @since ostermillerutils 1.00.00 */ @Override public void write( int b) throws IOException { out.write(b); md5.update(( byte )(b & 0xff )); } /** * Writes length bytes from the specified byte array starting a * offset off to this output stream. * * @param b the data. * @param off the start offset in the data. * @param len the number of bytes to write. * @throws IOException if an I/O error occurs. * * @since ostermillerutils 1.00.00 */ @Override public void write( byte b[], int off, int len) throws IOException { out.write(b, off, len); md5.update(b, off, len); } /** * Returns array of bytes representing hash of the stream so far. * * @return Array of 16 bytes, the hash of all written bytes. * * @since ostermillerutils 1.00.00 */ public byte [] getHash(){ return md5.getHash(); } /** * Get a 32-character hex representation representing hash of the stream so far. * * @return A string containing the hash of all written bytes. * * @since ostermillerutils 1.00.00 */ public String getHashString(){ return md5.getHashString(); } } |