我尝试从上下文接收类的bean,然后将其保存在mongodb集合中。问题是,由于未知原因,所有属性都在保存之前设置为null。当我尝试将对象保存在由new
运算符创建的数据库中时,它非常有效,但不能用于bean:
public static void main(String[] args) {
ApplicationContext ctx;
ctx = new ClassPathXmlApplicationContext("context.xml");
Komputer komputer = (Komputer)ctx.getBean("komputer");
Dao dao = (Dao)ctx.getBean(Dao.class);
dao.deleteAll();
System.out.println("inserting: " + komputer.getTyp());
dao.save(komputer); // sets everything to null and puts in db
Komputer new_komputer = new Komputer();
new_komputer.setTyp("test");
System.out.println("inserting: " + komputer.getTyp());
dao.save(new_komputer); // correctly puts in db
Iterable <Komputer> komputer_iterable = dao.findAll();
System.out.println("List: ");
for (Komputer komputer : komputer_iterable) {
System.out.println("id:" + komputer.getId() + ", typ: " + komputer.getTyp());
}
}
结果在控制台中打印:
inserting: Intel Pentium B970
13:33:38.719 [main] DEBUG o.s.data.mongodb.core.MongoTemplate - Inserting DBObject containing fields: [_class, _id, obwodKola, liczbaLosowa] in collection: komputer
13:33:38.720 [main] DEBUG o.s.data.mongodb.core.MongoDbUtils - Getting Mongo Database name=[lab_test]
inserting: test
13:33:38.726 [main] DEBUG o.s.data.mongodb.core.MongoTemplate - Inserting DBObject containing fields: [_class, _id, typ, obwodKola, liczbaLosowa] in collection: komputer
13:33:38.726 [main] DEBUG o.s.data.mongodb.core.MongoDbUtils - Getting Mongo Database name=[lab_test]
13:33:38.730 [main] DEBUG o.s.data.mongodb.core.MongoTemplate - find using query: { } fields: null for class: class org.zut.lab1.Komputer in collection: komputer
13:33:38.731 [main] DEBUG o.s.data.mongodb.core.MongoDbUtils - Getting Mongo Database name=[lab_test]
List:
id:56657ca244ae837d313d8b29, typ: null
id:56657ca244ae837d313d8b2a, typ: test
当然,所有第一个对象属性都设置正确。
这就是dao类的样子:
import org.springframework.data.repository.CrudRepository;
public interface Dao extends CrudRepository<Komputer, String> {
}
还有Komputer课:
import org.springframework.data.annotation.Id;
public class Komputer {
@Id
private String id;
private Procesor procesor;
private String typ;
private float obwodKola; // 2 * pi * r
private float liczbaLosowa;
public void setProcesor(Procesor procesor) {
this.procesor = procesor;
}
public Procesor getProcesor() {
return this.procesor;
}
public void setTyp(String typ) {
this.typ = typ;
}
public String getTyp() {
return this.typ;
}
public float getObwodKola() {
return obwodKola;
}
public void setObwodKola(float obwodKola) {
this.obwodKola = obwodKola;
}
public float getLiczbaLosowa() {
return liczbaLosowa;
}
public void setLiczbaLosowa(float liczbaLosowa) {
this.liczbaLosowa = liczbaLosowa;
}
public String getId() {
return id;
}
public void setId(String id) {
this.id = id;
}
}
context.xml文件中的Bean:
<mongo:mongo id="mongo" host="localhost" port="27017" />
<bean id="mongoTemplate" class="org.springframework.data.mongodb.core.MongoTemplate">
<constructor-arg ref="mongo" />
<constructor-arg name="databaseName" value="lab_test" />
</bean>
<mongo:repositories base-package="org.zut.lab1"></mongo:repositories>
<bean id="procesor" class="org.zut.lab1.Procesor">
<property name="iloscRdzeni" value="4"/>
<property name="czestotliwosc" value="300000"/>
</bean>
<bean id="komputer" class="org.zut.lab1.Komputer">
<property name="liczbaLosowa" value="#{T(java.lang.Math).random() * procesor.czestotliwosc}"/>
<property name="procesor" ref="procesor"/>
<property name="obwodKola" value="#{T(java.lang.Math).PI * 2 * procesor.getIloscRdzeni()}"/>
<property name="typ" value="Intel Pentium B970"/>
</bean>
这让我完全迷失方向。我做错了什么?
答案 0 :(得分:1)
基本上,Spring AOP为id为Proxy
的bean实例创建komputer
。
在代理时,它调用代理方法(比如用Mockito
模拟时),但原始属性为null。如果您使用某些IDE(例如Eclipse)调试代码,您可以看到发生了什么。
因此,当您保存代理实例时,它需要attribute's
值,而不是 getters 。
如果从上下文中删除aop proxy
,将正确保存komputer bean。
<aop:aspectj-autoproxy/>
....
<aop:config>
<aop:aspect ref="profiler">
<aop:pointcut expression="execution(* org.zut.lab1.Komputer.oblicz(..)) and args(czas)"
id="test"/>
<aop:around method="profile" pointcut-ref="test"/>
</aop:aspect>
</aop:config>