电商系统Broadleaf文档翻译(九) – 扩展的服务extending services

来源:互联网 发布:mongodb 连接数据库 编辑:程序博客网 时间:2024/06/05 20:50

原文标题:extending services
原文出处:http://www.broadleafcommerce.com/docs/core/current/broadleaf-concepts/data-and-service-models/extending-services
译者:IT十年
译文链接:
http://www.ittenyear.com/410/broadleaf-extending-services/
本译文仅用于学习和交流目的,转载请保留原文链接和译文链接!

在某些情况下,需要改变BLC服务的默认操作。你可能需要在调用中添加新的操作,或者完全改变服务的实现方式。这时候,你就要熟悉扩展BLC服务的策略。有两种方式可以扩展一个服务的基本功能。大多数时候,你会希望保留基本功能,这是扩展一个服务的实现就可以了。如果你不想使用基本功能,或者你已经重写了每个方法method,那么直接实现服务接口更有意义。

扩展一个现有服务的实现
这里有一个服务,我们想对它稍作修改。在这种情况下,继承服务是最佳方式。在一个标准的取消订单调用中添加新的逻辑用于记录每个取消操作,这是合理的需求。要实现这个功能,就需要扩展CartServiceImpl
public class MyCartServiceImpl extends CartServiceImpl {

    @Override
    public void cancelOrder(Order order) {
        try {
            Logger.info("Cancelling order " + order.getId());
            super.cancelOrder(order);
        } catch (Exception e) {
            throw new OrderCancellationRuntimeException(e);
        }
    }

}

在这个例子中,我们重写了继承自父类的cancelOrder()方法:记录取消订单的日志,然后调用了父类的cancelOrder()方法。整个逻辑都写在try-catch块中,如果执行中有问题就会抛出OrderCancellationRuntimeException 异常。


要使新的服务扩展生效,首先要在BLC中注册这个服务扩展。因为我们要扩展CartService,所以要重写blCartService
<bean id="blCartService" class="com.mycompany.order.service.MyCartServiceImpl"/>
把这个bean定义添加到应用程序上下文中。完成后,当系统需要一个CartService 实例时, BLC就会实例化 MyCartService ,只要有订单被取消,新的cancelOrder()方法就会被调用了。

事务和AOP的注意事项

大部分BLC的服务使用@Transactional注解,这意味着Spring会把服务的实现包装在JDK代理中。JDK代理默认只会转换为接口而不是实际的运行时类型。所以如果你注入了blCartService bean并想把它转换成MyCartServiceImpl类型,就会抛出ClassCastException异常。


如果你想在CartService的实现中添加更多的方法就有问题了。快速解决这个问题的方法就是让MyCartServiceImpl 实现一个新增的接口。

重新实现一个完整的服务
有时候你可能想完全改变一个BLC服务的运行方式。比如因为环境原因,你只能从内部的web服务而不是标准数据库中获取目录信息,要实现这种操作,就要自己实现CatalogService 接口:从web服务获取产品信息再创建出相应的域对象。

注意:建议不要每次都从web服务中读取目录信息,这会降低BLC网站的性能,使用缓存是个不错的选择。从web服务返回的结果可以缓存在本地,一段时间后数据过期了才需要更新。

我们看一下这个类型是怎么实现的:
public class MyCatalogServiceImpl implements CatalogService {

    @Resource(name="myCatalogWebService")
    CachingCatalogWebService cachingCatalogWebService;

    public List<Product> findActiveProductsByCategory(Category category) {
        List<MyProduct> myProducts = cachingCatalogWebService.getProductsInCategory(category.getName());
        List<Product> products = new ArrayList<Product>();
        for (MyProduct myProduct : myProducts) {
            Product product = new ProductImpl();
            //TODO set all the product fields
            products.add(product);
        }
        return products;
    }
    //TODO implement the other methods from the CatalogService interface
}
在这个例子中,我们演示了一个自定义的CatalogService实现,它从自定义的web服务而不是默认数据库中获取目录信息。你会发现,这个服务的主要工作就是把web服务域对象转换成BLC域对象。
当然,类似其他的对BLC的修改,新的service也需要在应用程序上下文中指定。你要修改blCatalogService这个重要的bean id:
<bean id="blCatalogService" class="com.mycompany.catalog.service.MyCatalogServiceImpl"/>
参阅[扩展快速参考]获取更多bean id信息
0 0
原创粉丝点击