我想实现自己的ProductImpl
,而不是创建一个扩展ProductImpl
的新类,我想用自己的实现替换现有的ProductImpl
。
这里的问题是,我还在BLC_PRODUCT
表中添加了两列。现在,我想重新设计包含这两列的ProductImpl
类。
所以,我写了一个名为MyProductImpl
的类,看起来像这样..
@Entity
@Table(name = "BLC_PRODUCT")
@Inheritance(strategy = InheritanceType.JOINED)
//multi-column indexes don't appear to get exported correctly when declared at the field level, so declaring here as a workaround
@org.hibernate.annotations.Table(appliesTo = "BLC_PRODUCT", indexes = {
@Index(name = "PRODUCT_URL_INDEX",
columnNames = {"URL","URL_KEY"}
)
})
@Cache(usage = CacheConcurrencyStrategy.READ_WRITE, region="blProducts")
@AdminPresentationClass(populateToOneFields = PopulateToOneFieldsEnum.TRUE, friendlyName = "baseProduct")
@SQLDelete(sql="UPDATE BLC_PRODUCT SET ARCHIVED = 'Y' WHERE PRODUCT_ID = ?")
@DirectCopyTransform({
@DirectCopyTransformMember(templateTokens = DirectCopyTransformTypes.SANDBOX, skipOverlaps=true),
@DirectCopyTransformMember(templateTokens = DirectCopyTransformTypes.SANDBOX_PRODUCT_INVOKE),
@DirectCopyTransformMember(templateTokens = DirectCopyTransformTypes.MULTITENANT_CATALOG)
})
public class MyProductImpl implements Product, Status, AdminMainEntity, Locatable
{
// all the code from ProductImpl pasted here..
@Column(name="MY_CLASS_ID")
@ManyToOne(targetEntity = MyClass.class)
protected MyClass myclass;
@Column(name="MY_CLAZZ_ID")
@ManyToOne(targetEntity = MyClazz.class)
protected MyClazz myclazz;
}
这里,当我通过管理界面创建新产品时,不会调用setter方法,但会注入值(除了我的附加字段)。 实际上,这些附加字段的值应该在内部插入程序,而不是来自用户的直接输入。我怎么能这样做?
提前致谢。
答案 0 :(得分:1)
我假设你使用的是boradleaf 3.1.x。
因此,我将简要介绍一下如何从后端注入自定义关系。
您可以将org.broadleafcommerce.admin.server.service.handler.SkuCustomPersistenceHandler
您应该实现所需的方法,例如:org.broadleafcommerce.admin.server.service.handler.SkuCustomPersistenceHandler#canHandleAdd
要么
org.broadleafcommerce.admin.server.service.handler.SkuCustomPersistenceHandler#canHandleUpdate
之后你应该实现像:
这样的方法 org.broadleafcommerce.admin.server.service.handler.SkuCustomPersistenceHandler#add
和
org.broadleafcommerce.admin.server.service.handler.SkuCustomPersistenceHandler#update
如果这不是您想要的,请随时询问其他详细信息。