我有一个类Book
:
package book;
public class Book {
private String title;
public Book(String title) {
this.title = title;
}
public boolean equals(Object object) {
if(object instanceof Book) {
Book book = (Book) object;
return this.title.equals(book.title);
}
return false;
}
}
这是我的Aspect类和Configuration类:
package book;
@Aspect
@Component
public class Logging {
@Pointcut("execution(* java.lang.Object.equals(..))")
private void equals() {}
@Before("equals()")
public void log() {
System.out.println("logging...");
}
}
package book;
@Configuration
@ComponentScan
@EnableAspectJAutoProxy
public class Config {
}
这是我的测试类:
@RunWith(SpringRunner.class)
@ContextConfiguration(classes = Config.class)
public class LoggingTest {
@Value("#{new book.Book('book1')}")
private Book book;
@Value("#{new book.Book('book2')}")
private Book book2;
@Test
public void test() {
assertFalse(book.equals(book2));
}
}
这个测试类运行成功。但是没有打印期望的logging...
。你能告诉我我的代码有什么问题吗?
提前感谢!
Spring AOP与AspectJ不一样。与AspectJ相比,Spring AOP有很多限制,而且它只适用于Spring托管bean。在@Value
注释中使用脚本表达式创建的Book
对象不是Spring管理的bean,因此没有AOP功能应用于它们。