/* * Copyright (c) 2002-2012 Alibaba Group Holding Limited. * All rights reserved. * * 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. */ package com.alibaba.citrus.service.requestcontext.session.encrypter.impl; import static com.alibaba.citrus.springext.util.SpringExtUtil.*; import static com.alibaba.citrus.util.Assert.*; import static com.alibaba.citrus.util.StringUtil.*; import javax.crypto.Cipher; import javax.crypto.spec.SecretKeySpec; import com.alibaba.citrus.service.requestcontext.session.encrypter.AbstractJceEncrypter; import com.alibaba.citrus.springext.support.parser.AbstractSingleBeanDefinitionParser; import org.springframework.beans.factory.support.BeanDefinitionBuilder; import org.springframework.beans.factory.xml.ParserContext; import org.w3c.dom.Element; public class AesEncrypter extends AbstractJceEncrypter { public final static String ALG_NAME = "AES"; public final static int DEFAULT_KEY_SIZE = 128; private String key; private int keySize; private SecretKeySpec keySpec; public String getKey() { return key; } public void setKey(String key) { this.key = trimToNull(key); } public int getKeySize() { return keySize <= 0 ? DEFAULT_KEY_SIZE : keySize; } public void setKeySize(int keySize) { this.keySize = keySize; } @Override protected void init() throws Exception { assertNotNull(key, "no key"); byte[] raw = key.getBytes("UTF-8"); int keySize = getKeySize(); int actualKeySize = raw.length * 8; assertTrue(keySize == actualKeySize, "Illegal key: expected size=%d, actual size is %d", keySize, actualKeySize); keySpec = new SecretKeySpec(raw, ALG_NAME); } @Override protected Cipher createCipher(int mode) throws Exception { Cipher cipher = Cipher.getInstance(ALG_NAME); cipher.init(mode, keySpec); return cipher; } @Override public String toString() { return "AES(keySize=" + getKeySize() + ")"; } public static class DefinitionParser extends AbstractSingleBeanDefinitionParser<AesEncrypter> { @Override protected void doParse(Element element, ParserContext parserContext, BeanDefinitionBuilder builder) { attributesToProperties(element, builder, "keySize", "key"); } } }