java web企业级应用开发_Java Web应用的开发模式

ab1d93653a86508413c7015f1ea8fd08.png

一、概述

从互联网诞生的第一天起,web从一个简单的静态页面,发展到今天五花八门、令人眼花缭乱的复杂应用,大到企业级的web应用系统,小到简单的SPA管理系统。在硬件性能提升的同时,通过各种技术实现了海量数据存储、解决了高并发的性能瓶颈、追求极致的用户体验等。从前端到后端,随着业务需求的变更和技术的更新迭代,开发模式也随之发生着改变。

二、原则

从软件工程的层面来看,开发一个系统,不仅是为了要完成业务目标。同时,还应该关注实现的过程和在实现过程中所采用的方式方法。

关注点分离

高内聚、低耦合

可维护性、可扩展性、可重用性

三、发展史

1、传统JSP模式

也称为web 1.0时代。基于传统的网页HTML文件,可以作为页面来浏览。同时,又兼容java代码,可以用来处理业务逻辑。对于功能单一、需求稳定的项目,可以把页面展示逻辑和业务逻辑都放到JSP中。

优点:编程简单,易上手,容易控制

缺点:前后端职责不清晰,可维护性差

2、Model1模式

可看做是对传统JSP模式的增强。加入了JavaBean或Servlet,将页面展示逻辑和业务逻辑做了分离。JSP只负责显示页面,JavaBean或者Servlet负责收集数据,以及返回处理结果。

优点:架构简单,适合中小型项目

缺点:虽然分离出业务逻辑,但是JSP中仍然包含页面展示逻辑和流程控制逻辑,不利于维护

3、Model2模式

该模式也可以看做是传统MVC模式。为了更好地进行职责划分,将流程控制逻辑也分离了出来。JSP负责页面展示,以及与用户的交互,展示逻辑;Servlet负责控制数据显示和状态更新,控制逻辑;JavaBeans负责操作和处理数据,业务逻辑。

优点:分工明确,层次清晰,能够更好地适应需求的变化,适合大型项目

缺点:相对复杂,严重依赖Servlet API,JavaBean组件类过于庞大

4、后端MVC模式

该模式是在Model2的基础上,对传统MVC模式的一种变化。涌现出很多基于MVC模式的开发框架,如Struts、SpringMVC等。再加上Spring开源框架强大的兼容特性,进而形成了可以适应绝大多数业务需求的经典框架组合,如SSH、SSM等。

前端开发重度依赖后端开发环境

前后端职责依旧纠缠不清,Controller成为灰色地带

5、前端MVC模式(SPA)

随着Ajax的推出,标志着进入了web 2.0时代。前后端分工明确,通过Ajax接口关联,浏览器端变得复杂。

前后端可以在约定接口后实现高效并行开发

前端开发的复杂度控制比较困难

6、前端为主的MV*模式

为了降低前端开发复杂度,涌现了大量的前端框架,如EmberJS、KnockoutJS、AngularJS等。原则是先按照类型分层,如Templates、Controllers、Models等,然后在层内按照业务功能切分。

好处:

前后端职责清晰,在各自的工作环境开发,测试容易

前端开发的复杂度可控,通过组件化组织结构

部署相对独立

不足:

前后端代码不能复用

全异步不利于SEO

性能并非最佳,尤其是移动互联网的环境下

SPA不能满足所有需求

7、全栈模式

随着Node.js的兴起,标志着全栈时代的到来,如MEAN框架组合、React+Redux等。前端UI层,处理浏览器层的展现逻辑,HTML+CSS+JavaScript。后端UI层,处理路由、模板、数据获取等,前端可以自由调控。后端可以专注于业务逻辑层的开发。

好处:

前后端的部分代码可以复用

需要SEO可以在服务端同步渲染

请求太多导致性能问题可以通过服务端缓解

挑战:

需要前端对服务端编程有进一步的了解

Node层与Java层能否高效通信尚需要验证

需要更多经验才能对部署、运维层面熟悉了解

还有许多历史遗留问题

四、总结

模式没有好坏高下之分,只有是否合适

Ajax给前端开发带来了一次质的飞跃,Node很可能是第二次

关注点分离是一条伟大的原则,本质上都是让前后端的职责更清晰,分工更合理高效

让合适的人做合适的事,前端的专注前端,后端的专注后端,各司其职

参考文章:

lifesinger:Web 研发模式演变

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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值