`
lee79
  • 浏览: 106745 次
  • 性别: Icon_minigender_1
  • 来自: 上海
社区版块
存档分类
最新评论

Web API应用架构设计分析(1)

 
阅读更多

Web API 是一种应用接口框架,它能够构建HTTP服务以支撑更广泛的客户端(包括浏览器,手机和平板电脑等移动设备)的框架, ASP.NET Web API 是一种用于在 .NET Framework 上构建 RESTful 应用程序的理想平台。本文主要以ASP.NET Web API 的框架实现来介绍整个Web API应用架构设计,但不局限于.NET的技术。

1、Web API的核心层设计

在 目前发达的应用场景下,我们往往需要接入Winform客户端、APP程序、网站程序、以及目前热火朝天的微信应用等,这些数据应该可以由同一个服务提 供,这个就是我们所需要构建的Web API平台,基于上述的需求,很多企业的需求都是以Web API优先的理念来设计整个企业应用体系的。Web API作为整个纽带的核心,在整个核心层需要考虑到统一性、稳定性、以及安全性等方面因素。

 

从上图我们可以看到,整个外围的应用场景围绕着Web API核心层构建,如果我们把它换一种方式表达,那么也就是下面的设计图示,我们把微信应用、APP应用、Web应用、Winform应用,作为Web API接口层上面的一个界面应用层来处理,这样就是基于一个API接口层,接入多个或多种方式的界面应用层,从而构建企业丰富的数据服务应用。

由于Web API层作为一个公共的接口层,我们就很好保证了各个界面应用层的数据一致性,如果考虑到响应式的集成处理,我们甚至可以把微信应用、APP应用、Web 应用做层一套Web程序,即使为了利用各自应用的特殊性,也可以把这些应用做的很相似,这样就给用户提供了一个统一的界面表示方式,极大提高客户使用的界 面体验效果,用户几乎不需要额外的界面学习,就可以熟悉整个应用体系的各个模块使用。

在整个WebAPI下面可以通过业务逻辑层整合数据存储和外部接口访问两部分工作,也就是数据访问层、外部接口层这样的分层概念,如果扩展开来,我 们还可以提供给客户一些文件、图片、视频等资料的文件存储,类似微信的多媒体API接口一样,这样整个Web API的接口层就能为所有接入的客户端提供丰富的数据接口,从而实现强大的、灵活的接入。

上面提到了如果考虑到响应式的集成处理,我们甚至可以把微信应用、APP应用、Web应用做层一套Web程序,其实APP应用层,可以分为两种类 型,一种是原生的APP类型,采用原生语言如Object C来开发IOS应用,采用java来开发安卓的原生应用一样;还有一种是封装一个入口的原生框架+后台响应式Web页面,如下图所示。

对比原生应用,采用入口框架+响应式页面的方式,开发效率非常快、升级维护成本也可以降低很多,比较Web开发总比使用原始APP开发快捷得多。

从上面的架构分析来看,我们的Web API作为核心层,可以在上面开发我们各种企业业务应用,

在目前比较热门的会员管理、客户管理等方面,结合微信的应用催化剂,就可以做的更加符合移动的潮流,从而实现我们“互联网+”的应用落地。

 

2、Web API层在Winform混合框架中的应用

同样,在Winform界面里面,我们除了可以利用直接访问数据库方式,以及采用访问分布式WCF服务的方式接入,还可以使得它能够访问Web API的数据服务,从而构建成一个适应性更加广泛、功能更加强大的混合式开发框架模式。

安全性方便,直接访问数据库方式,没有在网络上公开接口,它们只是在单机或者局域网安全的环境运行,因此只需要确保数据库的安全即可,一般可以通过加密连接字符串方式实现一定的限制即可。

WCF服务的安全性,可以通过X509证书方式实现校验,也还可以利用自定义的用户名、密码验证方式进行检查等等。

对于Web API,由于它提供的是一种无状态的接口访问,而且往往Web API一般为了多种客户端接入的需要,可能需要发布在公网上进行访问,因此我们需要更加注重Web API接口层的安全性,这方面我们后面详细介绍。

也就是新型的混合式开发框架,除了直连数据库访问的传统模式,WCF分布式访问的WCF服务访问模式,还可以接入API分布式访问的Web API接口模式,他们的关系构成了一个完整的Winform应用体系,如下图所示。

下面图示是我的基于传统访问数据库方式和分布式WCF数据服务访问方式的一个模块分析图,围绕着混合型框架的核心,我们可以构建很多松散耦合的模块,从而能够为我们Winform应用的开发集成提供更高的开发效率。

混合型框架可以看成是Winform框架高级版本,除了它本身是一个完整的业务系统外,它外围的所有辅助性模块均(如通用权限、通用字典、通用附件 管理、通用人员管理。。。。)都实现了这种混合型的框架,因此使用非常方便,整个框架如果简化来看,就是在原有的Winform界面层,用接口调用方式, 避免和业务逻辑类的紧耦合关系。由于它是通过接口方式的调用方式,它本身又可以通过配置指定指向WCF的实现,因此也囊括了WCF框架的一切特点。在完成 Web API层的开发后,基于Web API层的整合就是我下一个阶段的工作了。

 

我们进一步分析混合式框架的实现细节,原来考虑的传统Winform访问数据库和WCF服务访问方式,就是通过一个配置模块,确定是采用直接访问数 据库方式,还是访问WCF服务的方式,它们两者是统一到一个Facade接口门面层上,如果考虑到Web API层,基于混合式的架构,也就是在这个Facade接口门面层上增加多一个Web API的接口的封装成即可。具体整个框架的架构图如下所示。

 

主要研究技术:代码生成工具、Visio二次开发、客户关系管理软件、病人资料管理软件、送水管理软件等共享软件开发
专注于Winform开发框架Web开发框架、WCF开发框架、微信门户开发框架的研究及应用。
  转载请注明出处:
撰写人:伍华聪  http://www.iqidi.com

 

http://www.cnblogs.com/wuhuacong/p/4614875.html

分享到:
评论

相关推荐

    c# WebApi Winform托管

    总之,"c# WebApi Winform托管"是一个将Web服务功能引入桌面应用的实践,它允许在Winform应用内直接运行WebAPI,提高了开发效率,并简化了系统架构。同时,子线程访问UI确保了用户体验的流畅性,避免了因为后台操作...

    .NET WebApi 发布到服务器(windows)并开放端口

    .NET WebApi 是微软推出的一个基于 ASP.NET 架构的 Web API 框架,用于构建 RESTful 风格的 Web 服务。为了将 .NET WebApi 发布到 Windows 服务器上并开放端口,需要配置 IIS(Internet Information Services)...

    无iis启动webapi

    描述中提到的“AspNet.WebApi库”是微软提供的用于构建RESTful服务的框架,它基于ASP.NET MVC(Model-View-Controller)架构。Web API允许开发者创建HTTP服务,这些服务可以被任何HTTP客户端访问,包括浏览器、移动...

    WebApi和访问WebApi两个项目(更新过)

    总结起来,"WebApi和访问WebApi两个项目(更新过)"涉及到的知识点包括WebApi的基本架构、控制器设计、路由配置、模型绑定、过滤器、HttpClient的使用、异步编程、JSON数据交互以及错误处理。通过这些技术,开发者...

    K3 Cloud WebAPI接口说明书_V4.0.docx

    K3 Cloud WebAPI 的架构基于 Kingdee.BOS.WebApi.FormService.dll、Kingdee.BOS.WebApi.ServicesStub.dll 和 Kingdee.BOS.WebApi.Client.dll 三个组件。这些组件提供了从接口定义到接口调用的一整套解决方案。 技术...

    webapi 项目代码及winform下调用接口

    1. **WebAPI基础** - **RESTful原则**:WebAPI遵循REST(Representational State Transfer)架构风格,通过HTTP方法(GET、POST、PUT、DELETE等)来操作资源,实现客户端和服务器之间的通信。 - **路由配置**:Web...

    C# WEB API

    **C# Web API详解** ...它的设计思想是简洁、易于理解和使用,使得开发者可以快速构建跨平台的API应用,服务于各种客户端。通过深入学习和实践,我们可以充分利用Web API的特性,构建出高性能、健壮的Web服务。

    使用WebApi方式访问JPG和PDF

    Web API是基于REST(Representational State Transfer)架构原则构建的应用程序编程接口,它通过HTTP方法(如GET、POST、PUT、DELETE等)与服务器交互。开发者可以创建API,使得客户端能够获取、更新或删除服务器上...

    C#webapi文件上传下载源码

    1. **C# WebAPI基础**:理解WebAPI的基本架构,包括路由配置、控制器、HTTP动词(GET, POST等)以及模型绑定。 2. **MVC模式**:WebAPI基于Model-View-Controller模式,其中控制器负责处理请求和响应。 3. **...

    C# web 三层架构设计

    本文将深入探讨C# Web三层架构的设计原理,以及如何通过这一架构模式来构建高效、健壮的Web应用程序。 #### 二、C# Web 三层架构概述 ##### 表示层(Presentation Layer) 表示层,也称作UI层或Web层,是应用程序...

    在WEB API中启用session

    在Web API中启用Session涉及到的是将传统的Web应用程序中的会话状态管理应用到API设计中。Web API通常是无状态的,因为它遵循RESTful架构原则,但有时我们可能需要在某些场景下存储客户端的状态信息,这时就需要考虑...

    WebAPIDemo.rar_c# web api

    1. **RESTful原则**:Web API设计遵循REST(Representational State Transfer,表述性状态转移)架构风格,这意味着它通过HTTP协议提供资源,使用标准HTTP方法(GET、POST、PUT、DELETE等)进行操作,实现了无状态、...

    K3 Cloud WebAPI接口说明书_V2.0

    - **目的**:该文档的主要目的是为开发者提供K3 Cloud WebAPI的使用指南,以便他们能够构建和集成基于K3 Cloud的数据应用和服务。 - **范围**:文档覆盖了从基础的API调用到复杂的业务流程自动化的所有方面,包括...

    软考系统架构设计师-论云原生架构及其应用范文

    软考系统架构设计师-论云原生架构及其应用范文 云原生架构是指基于微服务和容器技术的架构设计原则,它有四类设计原则:服务化、强韧性、可观测性和自动化。云原生架构可以将应用分解为多个服务,每个服务可以选择...

    zabbix web应用架构分析

    本文通过源码分析,探究zabbix web应用的整体架构,所有分析基于zabbix 3.0.10进行。 总体而言,zabbix web应用使用PHP开发,大量应用OOP方法,主要采用mvc架构,同时包含一套遵循JSON-RPC 2.0协议的web API。 由于...

    WebApi和访问WebApi

    在实际项目中,WebApi常与MVC(Model-View-Controller)架构结合,提供前后端分离的解决方案,而HttpWebRequest则常被用在桌面应用、移动应用或其他服务器端程序中,作为数据获取和提交的主要手段。在学习和使用过程...

    使用ASP.NET Core 5.0构建WebApi框架源码

    通过阅读和分析这些源码,你可以深入了解ASP.NET Core 5.0的架构设计、路由配置、模型绑定、过滤器、授权策略等高级话题。同时,它也能帮助你掌握如何利用C#语言特性与.NET Core 5.0框架相结合,实现高效且可靠的Web...

Global site tag (gtag.js) - Google Analytics