设计模式:我与Facade模式的亲密接触

 

Facade模式,我对她可谓另眼相看----无声无息,她已经融入到了我们的生活中了!
 
Facade模式其实就是我非常认同的“Client Focus”的编程思想的一个具体体现。
子系统无论多么复杂,我们暴露给Client的接口一定要简单,方式也一定要简单。

解释一下我所认为的Client Focus:
我认为编程应该以Client为中心,
1,让Client调用简单,能不要Client做的事情尽量不要让Client做
2,让Client保持稳定,任何重构/修改尽量不要涉及到Client的改动

OK,言归正传,回顾一下我的一些Facade经历:

亲密接触一:
在做VMM系统的时候,Leader就提出我们需要写一个叫做VmmAPI的类给Web Client来Call。
所有Server端的功能需要暴露给Client调用的功能,全部集中放在VmmAPI中,
这样一来,对于Client来讲,我们只需要认识VmmAPI一个类就可以了,再也不用东找西找。
可以说,这个VmmAPI类,其实就是一个VmmFacade,是Vmm系统中最大的一个Facade,
它包含了Client需要调用的所有Server端的Service接口以及其他相关接口。

亲密接触二:
记得当年在佛山移动做vas外包项目时(日子那个苦啊~~~),第一次亲密接触单点登陆SSO(Single Sign On),
当年沉溺于单点登陆的实现细节,没有多想单点登陆的意义。

从用户的角度来看,似乎比较浅显:
公司里面,现存有人事/财务/销售/OA/论坛/等系统,往往我们登陆每个系统之前,总需要输入用户名/密码,
每个系统的用户名/密码还不一样,所以就需要我们记住每个系统的用户名和密码,不要搞错,
即使我们把每个系统的用户名密码都设为一样,但至少,我们需要登陆每个系统前都输入一次...
另外,我们还得记住各大系统的访问地址,那个麻烦啊~~~

在这种背景下,单点登陆产生了:
单点登陆只需要用户登录一次,就可以直接访问人事/财务。。等系统了。

单点登陆的好处有:
(1)不用记很多用户名和密码,只记一个用户名和密码就ok了。
(2)不用记很多系统的地址 ,只记一个登陆地址就ok了

如今,用设计模式的观点来看,所谓单点登陆,不外乎就是一个Facade,是各大系统的facade。
我们在SSO登陆后的页面,就可以看到所有关联系统了。

亲密接触三:
我在UT负责OMC-S软件开发,Brother Team包括有OMC-M,OMC-T,OMC-I等。OMC-S主要是管理Soft Switch软交换网络的,
,其他OMC系统负责其他网络的管理。用户管理不同的网元,需要登录对应的OMC-X来管理。
正如单点登陆一样,用户后来对这种操作方式表示不满。所以,公司开发了一个iNMS系统,
iNMS是驾驭在OMC系统之上的,其功能集成了下面各大OMC系统的功能。
那么以后用户就只需要登录iNMS一个系统,就可以完成OMC-S/OMC-M/OMC-I...等系统的操作了。

iNMS不就是一个OMCs的Facade么?

亲密接触四:
系统大了,配置文件也慢慢增多。配置文件可谓琳琅满目,各式各样,放的路径也多如牛毛。
久而久之,配置文件的管理变得臃肿而凌乱。
我们的OMC-S系统几年下来,配置文件多到吓死人!
VMM也是这样一个系统。从最开始只有几个配置文件,到后来越来越多,多到开发人员都记不太清楚到底放哪里了。

后来,我想到一个Solution.
做一个总的配置文件(比如UserConf.conf),把用户需要配置的信息统一在这个文件配置。
再由程序负责把这个配置文件的信息配置到(其实就是写文件)各个具体的配置文件中。
如此,用户和程序员就只用关心一个配置文件--UserConf.conf.
好处就是:再不用记各中配置文件的存放的位置了。

UserConf.conf其实就是一个配置文件的Facade.

亲密接触五:
平安保险最近推出了一个名曰“一帐通”的系统。
一帐通系统不但整合了平安自己旗下的所有产品(保险/银行/证券/信托/企业年金等),
还重磅推出了整合“非平安帐户”的功能。
整合“非平安帐户”的功能是什么样的一个功能呢?
简单来说,就是登录平安一帐通系统后,
你可以添加其他银行/证券/社保/邮箱/手机等网络帐号,一帐通系统帮用户保存好用户/密码,
之后,用户登陆平安“一帐通”系统后,就可以看到和自己相关的所有网上帐号信息:
我试用了一下,感觉功能非常强大。
从此以后,我再也不用登陆其他网上系统了,
"一套密码打开全部账户" ,我只需登陆平安的“一帐通”系统,然后就可以看到我所有网上信息了。
我的信用卡、我的证券、我的网银、我的社保、我的手机、我的邮箱、
我的基金、我的寿险、我的产险、我的企业年金....

那个功能之强大啊,使用之方便啊,感慨良多......

平安的一帐通其实就是一个SSO,也是一个Facade,平安的一帐通是网上应用系统SSO,
是用户所有网上系统的facade。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值