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 119
/* * Copyright 1999-2005 The Apache Software Foundation. * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. * */ /* * Copyright 2005 Sun Microsystems, Inc. All rights reserved. */ /* * $Id: DigesterOutputStream.java,v 1.1.2.2 2005/08/12 18:15:35 mullan Exp $ */ package org.jcp.xml.dsig.internal; import java.io.ByteArrayInputStream; import java.io.InputStream; import java.io.OutputStream; import java.security.MessageDigest; import java.util.logging.Logger; import java.util.logging.Level; import com.sun.org.apache.xml.internal.security.utils.UnsyncByteArrayOutputStream; /** * This class has been modified slightly to use java.security.MessageDigest * objects as input, rather than * org.apache.xml.security.algorithms.MessageDigestAlgorithm objects. * It also optionally caches the input bytes. * * @author raul * @author Sean Mullan */ public class DigesterOutputStream extends OutputStream { private boolean buffer = false; private UnsyncByteArrayOutputStream bos; private final MessageDigest md; private static Logger log = Logger.getLogger("org.jcp.xml.dsig.internal"); /** * Creates a DigesterOutputStream. * * @param md the MessageDigest */ public DigesterOutputStream(MessageDigest md) { this(md, false); } /** * Creates a DigesterOutputStream. * * @param md the MessageDigest * @param buffer if true, caches the input bytes */ public DigesterOutputStream(MessageDigest md, boolean buffer) { this.md = md; this.buffer = buffer; if (buffer) { bos = new UnsyncByteArrayOutputStream(); } } /** @inheritDoc */ public void write(byte[] input) { write(input, 0, input.length); } /** @inheritDoc */ public void write(int input) { if (buffer) { bos.write(input); } md.update((byte)input); } /** @inheritDoc */ public void write(byte[] input, int offset, int len) { if (buffer) { bos.write(input, offset, len); } if (log.isLoggable(Level.FINER)) { log.log(Level.FINER, "Pre-digested input:"); StringBuffer sb = new StringBuffer(len); for (int i=offset; i<(offset+len); i++) { sb.append((char) input[i]); } log.log(Level.FINER, sb.toString()); } md.update(input, offset, len); } /** * @return the digest value */ public byte[] getDigestValue() { return md.digest(); } /** * @return an input stream containing the cached bytes, or * null if not cached */ public InputStream getInputStream() { if (buffer) { return new ByteArrayInputStream(bos.toByteArray()); } else { return null; } } }