Мое первое усилие было плохим, но я торопился. Приношу извинения. Теперь я думаю, что знаю, как это должно работать, потому что я считаю, что я сам реализовал то, что вы хотите.
Я начал с класса учетных данных (примечание: нет интерфейса):
package aop;
import org.springframework.context.ApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext;
public class Credential
{
private static final String DEFAULT_USERNAME = "username";
private static final String DEFAULT_PASSWORD = "password";
private String username;
private String password;
public static void main(String[] args)
{
Credential cred1 = new Credential("foo", "bar");
System.out.println("created using new: " + cred1);
ApplicationContext context = new ClassPathXmlApplicationContext("classpath:aop-context.xml");
Credential cred2 = (Credential) context.getBean("credential");
System.out.println("created using app context: " + cred2);
String password = ((args.length > 0) ? args[0] : "baz");
cred2.setPassword(password);
System.out.println("initialized using setter: " + cred2);
}
public Credential()
{
this(DEFAULT_USERNAME, DEFAULT_PASSWORD);
}
public Credential(String username, String password)
{
this.setUsername(username);
this.setPassword(password);
}
public String getUsername()
{
return username;
}
public void setUsername(String username)
{
this.username = username;
}
public String getPassword()
{
return password;
}
public void setPassword(String password)
{
this.password = password;
}
public String toString()
{
return new StringBuilder().append("Credential{").append("username='").append(username).append('\'').append(", password='").append(password).append('\'').append('}').toString();
}
}
Я создал интерфейс Decryptor:
package aop;
public interface Decryptor
{
String decrypt(String encrypted);
}
И DecryptorImpl:
package aop;
public class DecryptorImpl implements Decryptor
{
public static final String DEFAULT_DECRYPTED_VALUE = " - not secret anymore";
public String decrypt(String encrypted)
{
// Any transform will do; this suffices to demonstrate
return encrypted + DEFAULT_DECRYPTED_VALUE;
}
}
1012 *
*
Мне нужен DecryptorAdvice для реализации SpringB MethodBeforeAdvice:
package aop;
import org.springframework.aop.MethodBeforeAdvice;
import java.lang.reflect.Method;
public class DecryptionAdvice implements MethodBeforeAdvice
{
private Decryptor decryptor;
public DecryptionAdvice(Decryptor decryptor)
{
this.decryptor = decryptor;
}
public void before(Method method, Object[] args, Object target) throws Throwable
{
String encryptedPassword = (String) args[0];
args[0] = this.decryptor.decrypt(encryptedPassword);
}
}
И я связал это вместе в aop-context.xml. (Если вы скажете мне, как заставить XML отображаться, я опубликую его.) Обратите внимание на passwordDecryptionAdvisor: он соответствует только методу setPassword.
Интересная часть происходит, когда я запускаю его. Вот что я вижу в консоли:
created using new: Credential{username='foo', password='bar'}
created using app context: Credential{username='stackoverflow', password='encrypted-password'}
initialized using setter: Credential{username='stackoverflow', password='baz - not secret anymore'}
Что это говорит мне:
- Если я создаю объект с новым
не под контролем Spring, совет
не применяется.
- Если я вызову setPassword в ctor
до того, как контекст приложения
инициализирован, совет не применяется.
- Если я позвоню setPassword в моем коде
после того, как контекст приложения
инициализировано, совет прилагается.
Надеюсь, это поможет вам.