最近做的这个项目,是一个外线管理系统。
外线人员使用android应用与服务端进行交互,内线人员使用浏览器访问系统。服务端既提供了给浏览器访问的页面,也暴露了一些接口给智能手机调用。
我原本觉得,这理所当然是一个C/S架构的应用,Server是服务端,Client是我们开发的android应用。不过今天看了一些关于B/S和C/S比较的帖子,回头又想了想,发现我原来的理解貌似不对。因此把一些想法记录在这里,以后再回顾一下。如果有朋友知道答案,也希望能指教一下,谢谢。
首先,我突然有点疑惑什么是所谓的web service。像我们服务端提供了一个地址,比如说http://localhost:8080/service/accept.action。然后我们的终端应用访问这个地址,并且传递一些参数进来,系统后台就做了一些逻辑处理,数据库操作什么的,然后返回一个响应回到android终端。
这种形式和我以前做过的web service就不太一样。以前系统A发布了一个web service,然后系统B是根据系统A的WSDL,直接调用系统A发布的一些方法。我理解这样才像一个web service。
但是现在这种形式,我感觉效果和上面的例子也是一样的,服务端就是发布web service的系统A,终端应用就是系统B,虽然它没有看到什么WSDL,但是它只要知道http://localhost:8080/service/accept.action这个地址,和这个地址需要的参数,照样可以访问到,并且也能让系统A作逻辑处理,也能得到系统A返回的结果。虽然这种形式上不是web service,但是实际的效果和web service又有什么区别呢?如果是这样的话,那么什么又才是真正的web service呢?
关于这个问题,我感到很疑惑,希望知道的朋友能给我讲解一下。
扯完题外话,再说回B/S和C/S。我原本认为我们这个系统肯定是C/S结构的,现在想想也不对劲。
终端应用和服务端的交互有2种方式,一种是走http协议,也是发起请求、获得响应、断开连接;另一种是通过走短信网关的方式,发送短信、解析短信。这2种方式,终端应用和服务端都没有保持长连接。如果服务端想推送什么消息到终端的话,是要通过向目标手机号发送特殊格式短信的方式来实现的。但是真正的C/S架构,却是可以通过Socket之类的长连接来即时推送消息的。
不过除了这点以外,我们又确实需要:
1、同时维护服务端系统和终端应用
2、负责终端应用的分发和升级
3、保证终端数据和服务端数据的同步
4、可以在终端应用上进行比较多的业务逻辑
上面这些特征又类似于传统的C/S架构,所以我现在也有点迷糊,究竟如何区分所谓的B/S和C/S呢?至少我认为我们这个系统不是纯粹的C/S,但是又不能说是B/S。。。
其实想想,也不用这么拘泥这个划分。除非一个系统和外部系统一点关系没有(比如安装一个单机的连连看),就一定涉及到如下问题:
1、系统职责划分(业务逻辑分配的比重)
2、系统间通信(HTTP、Socket……)
3、系统间数据同步
4、系统一致性(服务端升级,客户端需要相应升级)
5、部署和维护的成本
6、……
或许所谓的B/S、C/S,之间不存在也没必要某种绝对的划分,只要能处理好上述这些问题就行了。比如我们这次的系统,就可以算是一个B/S和C/S混搭的系统
分享到:
相关推荐
总结起来,C/S和B/S架构分别代表了本地应用和Web应用的两种典型模型,而分层和多层架构则提供了系统设计的组织原则,帮助我们构建灵活、可维护的大型软件系统。理解并熟练运用这些知识点,对于任何IT从业者来说都是...
### B/S结构与C/S结构详解 #### 一、B/S结构概述 **B/S结构**(Browser/Server,浏览器/服务器模式)是一种随着Web技术发展而兴起的网络结构模式。在此模式下,客户端的主要应用软件为Web浏览器,例如Netscape ...
C/S(Client/Server)结构和B/S(Browser/Server)结构是两种常见的软件系统架构,它们在多个方面有着显著的差异。 首先,C/S结构是基于局域网的,通常用于内部网络环境,其中客户端(Client)负责用户界面和部分...
教程可能涵盖如何使用Delphi构建一个简单的B/S系统,包括用户登录、数据查询、添加编辑删除记录等功能,以及如何处理错误和异常。 通过本教程的学习,开发者将能够掌握利用Delphi开发B/S数据库应用系统的技能,从而...
**C/S架构**,即Client/Server架构,是一种传统的计算机应用模式。在C/S架构中,客户端需要安装专门设计的软件来与服务器进行通信。服务器通常配置为高...总的来说,C/S和B/S架构的选择取决于具体的应用需求和环境。
总的来说,C/S架构适合于对界面和响应速度要求高,用户群稳定且对安全性有特殊要求的场景,而B/S架构则更适用于大规模的互联网应用,可以快速部署,易于维护,但可能在用户体验和性能上有所牺牲。在实际应用中,可以...
在信息技术的迅猛发展中,C/S(客户端/服务器)和B/S(浏览器/服务器)架构作为两种主流的软件设计模式,各自承载着独特的价值和应用场景。本文旨在深入探讨这两种架构的特点、优缺点以及它们在当前信息化社会中的...
为将Internet通信和嵌入式系统结合起来,设计了一款基于C/S和B/S结构相结合的嵌入式Web服务器。选用DS80C400作为主控芯片完成硬件设计,采用Java技术完成应用软件设计,并以西门子PLC作为现场设备通过以太网完成了对...
Web报表B/S系统是一种基于浏览器/服务器架构的报表解决方案,主要应用于数据分析、数据展示和决策支持。这种系统允许用户通过Web界面访问和交互各种报表,无需安装任何客户端软件,极大地提高了报表的分发效率和使用...
本系统结合了B/S(浏览器/服务器)与C/S(客户端/服务器)架构,旨在提供一个既灵活又功能丰富的测试环境。下面将详细介绍这两种架构以及它们在在线测试系统中的应用。 **B/S架构** B/S架构,即浏览器/服务器架构,...
【B/S和C/S的比较】是IT领域中关于软件架构设计的重要话题。这两种架构各自具有独特的特性和适用场景,理解它们的区别有助于我们选择合适的软件开发模式。 C/S(Client/Server)架构,又称为客户端-服务器架构,是...
### C/S与B/S的区别 ...综上所述,C/S架构和B/S架构各有优势,在选择时需根据具体的应用场景和需求来决定最适合的架构方式。随着技术的发展,两种架构也在不断地融合和发展,以适应更多样化的业务需求。
【标题】:“B/S架构系统通用客户端” 【描述】中提到的“B/S架构系统通用客户端”是一个专为运行在Windows操作系统上的应用设计的工具,它的主要功能是为用户提供一个无需安装、不依赖任何插件的便捷方式来连接...
在实现方面,***是Microsoft公司推出的一个用于构建Web应用程序的.NET框架,它包含了一系列开发工具和库,非常适合于开发B/S模式的Web应用程序。数据库方面,SQL Server是微软公司提供的关系数据库管理系统,它能与*...
在当前的软件开发领域中,客户端/服务器(Client/Server, C/S)架构和浏览器/服务器(Browser/Server, B/S)架构都是常见的应用部署方式。这两种架构各有优势,如何将它们有效地结合起来,成为了一个重要的研究方向。...
C/S (客户端/服务器) 和 B/S (浏览器/服务器) 是两种不同的软件体系结构,主要应用于构建分布式系统,特别是Web应用程序。理解这两种架构的关键在于它们的分层结构、客户端的功能以及与服务器的交互方式。 C/S 结构...
在IT行业中,B/S(Browser/Server,浏览器/服务器)架构是一种常见的软件系统设计模式,主要应用于Web应用程序。在这种架构中,用户通过浏览器与服务器进行交互,而无需安装任何特定客户端软件。标题提到的"B/S结构...
### B/S和C/S详解:理解两种架构的精髓 #### B/S架构:互联网时代的产物 B/S架构,即Browser/Server架构,是伴随着Internet技术的兴起而发展起来的一种新型架构模式,它改变了传统的C/S(Client/Server)架构中...