设计模式之--装饰者模式

认识装饰者模式

装饰者模式的定义:

不必改变原类文件和使用继承的情况下,动态地扩展一个对象的功能。它是通过创建一个包装对象,也就是装饰来包裹真实的对象。

代码开发中遵循开放-关闭原则,即类应该对扩展开放,对修改关闭。

举个栗子:假设我们开一间餐厅,就卖黄焖鸡米饭,黄焖鸡有大份、中份、小份,还可以加各种食材,比如香菇、宽粉、肥牛等等,还有各种饮料,加入我们为每一种品类都写一个类,并计算价格,类的数量就会非常多也就是造成类爆炸,另外就假如我的某各品类里面加入一种品类,那么就会修改之前写的那些类,违背了开闭原则。这个时候我们使用装饰者模式更合理。

装饰者模式的组件: 如下图

1.Component(被装饰对象的基类,通常为抽象类)

定义一个对象接口,可以给这些对象动态地添加职责。

2.ConcreteComponent(具体被装饰对象)

定义一个对象,可以给这个对象添加一些职责。

3.Decorator(装饰者抽象类)

  维持一个指向Component实例的引用,并定义一个与Component接口一致的接口。

4.ConcreteDecorator(具体装饰者)

  具体的装饰对象,给内部持有的具体被装饰对象,增加具体的职责

在这里插入图片描述
在上面的栗子中,黄焖鸡原料就可以是被装饰者对象ConcreteComponent,各种添加的食材就可以作为具体装饰者。不过今天我们不用上面的栗子演示,而是结合工作中具体的遇到的业务讲解。

业务实战

业务背景

笔者的公司正在做信息化转型,开始使用前后端分离架构,为了统一架构和方便开发,笔者为后端服务做了一个客户端SSO-Client,开发者引入这个Jar就可以完美接入企业的SSO认证,没有代码侵入。但是好景不长,部门其他团队在启用新项目时说我的客户端无法满足需求,深入了解才知道,原来部门的其他系统比如ECP/WMS,还有自己独立登录系统,他们可能引入外部客户(比如供应商、渠道),而公司之前的SSO服务只是管理到了公司员工,所以在此基础上,衍生出了新的需求。

1)项目除了接入SSO,还要接入第三方(可能是现有)的登录系统。
2)项目还需要有切换身份。

解决方案:

SSO-client兼容上述两种情况。通过客户端自定义配置的方式实现。1) 2)可能使用不同的Cookie实现,同时支持url和自定义实现类

最初的代码实现:

(1)定义SSOProperties:

 @ConfigurationProperties("spring.rj.sso")
public class SSOProperties {
    /**
     * 认证过滤器开关,默认为on.
     */
    private String flag;
    /**
     * 认证过滤器跳过的URI,多个用逗
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值