1.为什么要使用门面模式
门面模式几乎是所有大型企业级架构必备的模式。门面模式在概念上有点和模版方法模式上相似,即我不需要知道你具体执行的细节,只需要你给我提供一个对外的接口就行了。拿现在的理财类App为例,新用户注册之后都会发出来一大堆优惠券给你使用,让你体验。在没有门面的情况下,我们要先调用注册接口,判断手机号存不存在什么的,注册成功后再调用发送优惠券的接口,给用户发送优惠券。但是在有门面的情况下,只需要把注册接口的逻辑和发送优惠券的逻辑封装成一个接口,再由门面系统去暴露该接口即可。对于App来说,我只要调用该接口,就会完成注册和发送优惠券的整个逻辑。在目前的项目中,一般约定,所有接口都是由门面进行提供,下游系统的接口不会暴露在外网中。这样就规范了App的业务调用,防止App乱调用接口。
2.类图
Registe是注册系统,提供注册接口,Money是优惠券系统,提供优惠券接口。FacadeApi就是门面了,方便起见就不写接口了,直接调用。
3.实现
业务相关类
public class Registe {
public boolean registe(long id){
System.out.println("开始注册");
if(id > 500L){//假设id》500的是未注册的用户,可以注册
System.out.println("注册成功,id=" + id);
return true;
}
System.out.println("注册失败,id=" + id);
return false;
}
}
public class Money {
public void giveMoney(long id){
System.out.println("发优惠券啦!");
}
}
public class FacadeApi {
private Registe registe = new Registe();
private Money money = new Money();
public boolean registe(long id){
boolean isReg = registe.registe(id);
if(isReg){//注册成功才发送优惠券
money.giveMoney(id);
}
return isReg;
}
}
main方法
public class Main {
public static void main(String[] args) {
FacadeApi facadeApi = new FacadeApi();
//单单只需要调用facade暴露的接口即可
facadeApi.registe(600);
facadeApi.registe(400);
}
}
//输出结果
开始注册
注册成功,id=600
发优惠券啦!
开始注册
注册失败,id=400
4.总结
以上就是门面模式的一个小例子,在实际开发过程中,逻辑可能要复杂的多,注册成功之后可能也不仅仅是发送优惠券这一个操作。当操作多了以后,不免一个接口的耗时会越来越多。所以,此时就要考虑把一些附带的业务需求做成异步的,把压力分摊到其它中间件上面,比如MQ,减少接口调用时间。