java设计模式门面实际应用,Java设计模式之外观模式(门面模式)

什么是外观模式

外观模式(Facade),他隐藏了系统的复杂性,并向客户端提供了一个可以访问系统的接口。这种类型的设计模式属于结构性模式。为子系统中的一组接口提供了一个统一的访问接口,这个接口使得子系统更容易被访问或者使用。

外观模式应用场景

2728559fad67df31288cef32a49a5dd9.jpg

简单来说,该模式就是把一些复杂的流程封装成一个接口供给外部用户更简单的使用。这个模式中,设计到3个角色。

1.门面角色:外观模式的核心。它被客户角色调用,它熟悉子系统的功能。内部根据客户角色的需求预定了几种功能的组合。

2.子系统角色:实现了子系统的功能。它对客户角色和Facade时未知的。它内部可以有系统内的相互交互,也可以由供外界调用的接口。

3.客户角色:通过调用Facede来完成要实现的功能。

相关代码实现

需要重构代码

@Slf4j

@Component

public class PayCallbackService {

// 用户下单成功后,有那些操作?

// 1.增加支付回调接口日志

// 2.修改订单数据库状态为已经成功

// 3.调用积分服务接口

// 4.调用消息服务平台服务接口

public boolean callback(Map verifySignature) {

// 1.第一步打印日志信息

String orderId = verifySignature.get("orderId"); // 获取后台通知的数据,其他字段也可用类似方式获取

String respCode = verifySignature.get("respCode");

log.info("orderId:{},respCode:{}", orderId, respCode);

// 2.修改订单状态为已经支付

new PaymentTransactionMapper() {

@Override

public void updatePaymentStatus() {

log.info(">>>修改订单状态为已经支付>>>>>");

}

}.updatePaymentStatus();

// 3.调用积分接口增加积分

HttpClientUtils.doPost("jifen.com", "积分接口");

// 4.调用消息服务平台提示

HttpClientUtils.doPost("msg.com", "调用消息接口");

return true;

}

}

utils

@Slf4j

public class HttpClientUtils {

public static String doPost(String url, String text) {

log.info(">>>Url:{},text:{}", url, text);

return "success";

}

}

创建业务逻辑封装

@Slf4j

@Component

public class LogService {

public void log(Map verifySignature) {

String orderId = verifySignature.get("orderId"); // 获取后台通知的数据,其他字段也可用类似方式获取

String respCode = verifySignature.get("respCode");

log.info("1.第一个模块,打印日志模块:orderId:{},respCode:{}", orderId, respCode);

}

}

@Slf4j

@Component

public class PaymentService {

public void updatePaymentStatus() {

// 2.修改订单状态为已经支付

new PaymentTransactionMapper() {

@Override

public void updatePaymentStatus() {

log.info(2."第二个模块>>>修改订单状态为已经支付>>>>>");

}

}.updatePaymentStatus();

}

}

@Component

@Slf4j

public class IntegralService {

public void callIntegral() {

// 3.调用积分接口增加积分

HttpClientUtils.doPost("jifen.com", "积分接口");

log.info("3.第三个模块>>>调用积分接口打印日志>>>>>");

}

}

@Component

@Slf4j

public class MsgService {

public void callMsg() {

log.info("4.第四个模块 调用消息模块");

HttpClientUtils.doPost("msg.com", "调用消息接口");

}

}

创建门面接口:PayFacade

@Component

public class PayFacade {

@Autowired

private LogService logService;

@Autowired

private PaymentService paymentService;

@Autowired

private IntegralService integralService;

@Autowired

private MsgService msgService;

public String callback(Map verifySignature) {

logService.log(verifySignature);

paymentService.updatePaymentStatus();

integralService.callIntegral();

msgService.callMsg();

return "success";

}

}

PayCallbackController

@RestController

public class PayCallbackController {

@Autowired

private PayFacade payFacade;

@RequestMapping("/callback")

public String callback(@RequestBody Map verifySignature) {

String result = payFacade.callback(verifySignature);

return result;

}

}

mapper

public interface PaymentTransactionMapper {

void updatePaymentStatus();

}

启动类

@SpringBootApplication

public class AppFacade {

public static void main(String[] args) {

SpringApplication.run(AppFacade.class);

}

}

pom

org.springframework.boot

spring-boot-starter-parent

2.0.1.RELEASE

org.springframework.boot

spring-boot-starter-web

org.projectlombok

lombok

1.16.10

commons-lang

commons-lang

2.6

使用postman进行测试

0c991ab621adde0340c6ade1e4590c52.jpg

控制台输出

2019-05-25 23:12:54.773  INFO 1948 --- [nio-8080-exec-6] com.xuyu.service.LogService              : 1.第一个模块,打印日志模块:orderId:111,respCode:xuyucode

2019-05-25 23:12:54.774  INFO 1948 --- [nio-8080-exec-6] com.xuyu.service.PaymentService          : 2.第二个模块>>>修改订单状态为已经支付>>>>>

2019-05-25 23:12:54.775  INFO 1948 --- [nio-8080-exec-6] com.xuyu.service.IntegralService         : 3.第三个模块 调用积分模块

2019-05-25 23:12:54.775  INFO 1948 --- [nio-8080-exec-6] com.xuyu.utils.HttpClientUtils           : >>>Url:jifen.com,text:积分接口

2019-05-25 23:12:54.775  INFO 1948 --- [nio-8080-exec-6] com.xuyu.service.MsgService              : 4.第四个模块 调用消息模块

2019-05-25 23:12:54.775  INFO 1948 --- [nio-8080-exec-6] com.xuyu.utils.HttpClientUtils           : >>>Url:msg.com,text:调用消息接口

success

​​​​​​​

(adsbygoogle = window.adsbygoogle || []).push({});

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值