patch for problem with digest

git-svn-id: https://svn.berlios.de/svnroot/repos/yacy/trunk@6031 6c8d7289-2bf4-0310-a012-ef5d649a1542
pull/1/head
orbiter 16 years ago
parent 3029ef6eb3
commit a704d82280

@ -44,6 +44,8 @@ import java.util.concurrent.Executors;
import java.util.concurrent.Future; import java.util.concurrent.Future;
import java.util.concurrent.LinkedBlockingQueue; import java.util.concurrent.LinkedBlockingQueue;
import de.anomic.kelondro.util.Log;
public class Digest { public class Digest {
@ -109,23 +111,36 @@ public class Digest {
} }
public static byte[] encodeMD5Raw(final String key) { public static byte[] encodeMD5Raw(final String key) {
MessageDigest digest = null;
boolean fromPool = true;
try { try {
final MessageDigest digest = digestPool.take(); digest = digestPool.take();
byte[] keyBytes;
try {
keyBytes = key.getBytes("UTF-8");
} catch (UnsupportedEncodingException e) {
keyBytes = key.getBytes();
}
digest.update(keyBytes);
byte[] result = digest.digest();
digest.reset();
digestPool.put(digest);
return result;
} catch (InterruptedException e) { } catch (InterruptedException e) {
System.out.println("Internal Error at md5:" + e.getMessage()); Log.logWarning("Digest", "using generic instead of pooled digest");
try {
digest = MessageDigest.getInstance("MD5");
} catch (NoSuchAlgorithmException e1) {
e1.printStackTrace();
}
digest.reset();
fromPool = false;
} }
return null; byte[] keyBytes;
try {
keyBytes = key.getBytes("UTF-8");
} catch (UnsupportedEncodingException e) {
keyBytes = key.getBytes();
}
digest.update(keyBytes);
byte[] result = digest.digest();
digest.reset();
if (fromPool)
try {
digestPool.put(digest);
} catch (InterruptedException e) {
e.printStackTrace();
}
return result;
} }
public static byte[] encodeMD5Raw(final File file) { public static byte[] encodeMD5Raw(final File file) {

Loading…
Cancel
Save