/** * This software is licensed to you under the Apache License, Version 2.0 (the * "Apache License"). * * LinkedIn's contributions are made under the Apache License. If you contribute * to the Software, the contributions will be deemed to have been made under the * Apache License, unless you expressly indicate otherwise. Please do not make any * contributions that would be inconsistent with the Apache License. * * You may obtain a copy of the Apache License at http://www.apache.org/licenses/LICENSE-2.0 * Unless required by applicable law or agreed to in writing, this software * distributed under the Apache License is distributed on an "AS IS" BASIS, WITHOUT * WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the Apache * License for the specific language governing permissions and limitations for the * software governed under the Apache License. * * © 2012 LinkedIn Corp. All Rights Reserved. */ package com.senseidb.cluster.routing; import java.security.MessageDigest; import java.security.NoSuchAlgorithmException; import org.apache.log4j.Logger; public class MD5HashProvider implements HashProvider { private final static Logger logger = Logger.getLogger(MD5HashProvider.class); private final ThreadLocal<MessageDigest> _md = new ThreadLocal<MessageDigest>() { protected MessageDigest initialValue() { try { return MessageDigest.getInstance("MD5"); } catch (NoSuchAlgorithmException e) { logger.error(e); } return null; } }; /** * Hash the key into an integer. * * @param key * the key to be hashed * @return the hash code of the key */ public long hash(String key) { byte[] kbytes = _md.get().digest(key.getBytes()); long hc = ((long) (kbytes[3] & 0xFF) << 24) | ((long) (kbytes[2] & 0xFF) << 16) | ((long) (kbytes[1] & 0xFF) << 8) | (long) (kbytes[0] & 0xFF); _md.get().reset(); return Math.abs(hc); } }