设为首页 收藏本站
查看: 800|回复: 0

[经验分享] PHP与Spring之间的强势接口设计:学习案例

[复制链接]

尚未签到

发表于 2018-12-18 10:07:59 | 显示全部楼层 |阅读模式

高焕堂TCLUB微信讲座(2015/9/29)内容分享
从编程到设计.学习案例(1)

PHPSpring之间的强势接口设计


by 高煥堂(2015.10.1)



前言:
  这是高焕堂TClub微信讲座(2015/9/29)的内容,大家分享,欢迎免费加入TClub。详细请参考:http://www.cnblogs.com/SmartADT/。
大家都知道,要学好软件(或架构)设计,不是从业务或需求开始,而是从接口(Interface)设计出发,才是迅速成为有效(架构)设计师的鸟语花香之路。因为业务(或需求分析)的焦点在于流程(Business flow),而软件(架构)设计的天赋职责就在于结构(Structure),这结构是用来支撑互联网时代下的千变万化企业流程,而未来企业环境、需求与流程的是不可知的,所以才需要(架构)设计。
      因此,知道结构与流程是分别来自不同而互补的两个面向(Dimension),软件(架构)设计师必须基于两个不同视角(View)来设计架构和规划流程。因此,软件(架构)设计不是从业务(或需求)流程开始,而是从接口设计出发的,而接口不是从业务(领域)或需求抽象出来的。许多初学软件设计者常常迷失于其中,没关系的,我(高老师)陪您越过这个原野,驰聘于广阔无垠的软件世界。您可听听高老师怎么说=> 下载高老师视频(免费)
   
一、目标

  •   设计通用性(又称通用型)接口(Interface),让我们自己能掌握系统架构里的接口制定权,拥有话语权,所以是一种强势型接口。
  •   基于自己的接口,整合IWebShop、Spring和DBMS等外来平台框架,让这些外来的平台框架都成为可被我们抽换的架构性插件(Plugin)。
  •   自己制定的(通用性)接口,成为各服务器之间的必经渠道,我们可以设计抽象(父类)来实现这项接口,来监控交易(Transaction)流动和流量,例如我们可以设计一个”看门狗(watch dog)”的类。
  •   随着业务和系统的成长,将会增添更多上述的具象类(如watch dog类),逐渐形成我们自己的平台框架(Framework)了。
  •   基于自己制定的接口和框架,才能让外来平台框架成为可抽换,可新陈代谢的模块,以避免我们的成长受制于外来平台的接口和功能,确保我们能弹性成长,支撑成千上百万的业务应用功能,并稳定、永续茁壮。

二、从外来平台出发

  •   首先拿基于PHP的iWebShop和Spring两个外来的平台框架为例。
   

  •   我们来将两者分离。
   

  •   让两者便成为Loosely-Coupled。
   

  •   这项目目标实现途径就是:设计自己的;又称为。
   

三、的角色

  •   从业务应用(App)开发的视角来看,我们会在iWebShop框架里撰写特殊性业务逻辑,成为iWS App软件,并调用Sring框架里的共享性企业逻辑(Business logic, or Business object),以及DB Server里的数据。
     

  •   最典型的调用流程是:
     

  •   运用proxy-stub设计模式(Design pattern),让这iWS App可以掌握跨界的通信接口。
        


  •   这个iWS App就包含两部分,例如:iwsActivity(扮演proxy角色)和iwsService(扮演stub角色)。其分别置于分界线的两边。
        

  •   最典型的调用流程是:
     

  •   设计我们自己的通用性接口:
       

  •   其典型的调用流程是:
     

四、的设计要点:应用

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-652727-1-1.html 上篇帖子: php 获取时间 下篇帖子: PHP、Mysql等网站建设交流看我另一个博客
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表