龙空技术网

互联网项目的进步--前后端是怎么分离的?

还在卖鱼 200

前言:

而今你们对“jsp页面获取后端返回的数据类型是”可能比较关心,你们都需要分析一些“jsp页面获取后端返回的数据类型是”的相关资讯。那么小编也在网络上网罗了一些关于“jsp页面获取后端返回的数据类型是””的相关文章,希望小伙伴们能喜欢,你们快快来学习一下吧!

前后端是怎么分离的

当前互联网项目开发中,前后端分离几乎已经成为业界标准。并且,就目前趋势,前后端分离的开发模式将会是以后大型分布式架构,弹性计算架构,微服务架构以及多端化服务例如多种客户端,物联网终端,车载终端,手持设备等的坚实基础。

前后端分离的核心思想是前端Html页面通过Ajax调用后端Restful API接口并通过Json或Xml数据进行交互。后端只提供API用以响应前端请求。

当前,后端服务大致可分为以下两种即:

Web服务器:一般指像Nginx,Apache这类的服务器,他们一般只能解析静态资源。应用服务器:一般指像Tomcat,Jetty,Resin这类的服务器可以解析动态资源也可以解析静态资源,但解析静态资源的能力没有Web服务器好;

一般都是只有Web服务器才能被外网访问,应用服务器只能内网访问。

我们的问题,前后端为什么会分离?

首先,以前的Web项目中,大多数程序员既做前端又做后端,例如几年前非常流行的JSP项目,前后端耦合性非常大。往往修改前端页面后端服务也要跟着变化,开发复杂度相当高,例如早期主要使用MVC框架,Jsp+Servlet的结构图如下。

大致流程就是所有的请求都被发送给作为控制器的Servlet,它接受请求,并根据请求信息将它们分发给适当的JSP来响应。同时,Servlet还根据JSP的需求生成JavaBeans的实例并输出给JSP环境。JSP可以通过直接调用方法或使用UseBean的自定义标签得到JavaBeans中的数据。需要说明的是,这个View还可以采用 Velocity、Freemaker 等模板引擎。使用了这些模板引擎,可以使得开发过程中的人员分工更加明确,还能提高开发效率。

在这个开发时代,项目开发方式大致分为以下两种:

第一:

第二:

以上两种开发模式的缺点在于,前端无法单独调试,开发效率低,并且前端不可避免会遇到后台代码。

在总接以上开发模式的缺点及互联网的高速发展,在前后端完全分离之前,可以说出现过短暂的半分离状态期,在这一阶段,前端负责开发页面,通过接口(Ajax)获取数据,采用Dom操作对页面进行数据绑定,最终由前端把页面渲染出来。这也就是Ajax与SPA应用(单页应用)结合的方式,其结构图如下:

大致流程解释为:浏览器请求CDN返回HTML页面,HTML中的JS代码以Ajax方式请求后台的Restful接口,接口返回Json数据,页面解析Json数据,通过Dom操作渲染页面。

这种方式的优点是很明显的。前端不会嵌入任何后台代码,前端专注于HTML、CSS、JS的开发,不依赖于后端。

然而在这种框架之下也存在着相当多的弊端,例如:

JS存在大量冗余,在业务复杂的情况下,页面的渲染部分的代码,非常复杂。在Json返回的数据量比较大的情况下,渲染的十分缓慢,会出现页面卡顿的情况资源消耗严重,在业务复杂的情况下,一个页面可能要发起多次HTTP请求才能将页面渲染完毕

在不断的探索和进步后,终于node.js的出现,使前后端真正意义上得到分离。在这一阶段,前端负责MVC框架中的View和Controller层。后端只负责Model层,对业务/数据进行处理等。

node.js适合运用在高并发、I/O密集、少量业务逻辑的场景。最重要的一点是,前端只需要会JS开发你不需要再学习后端语言就可实现对Controller层的代码编写,对前端来说,简直是福音。

分离时代的结构图如下:

大致流程是:浏览器请求服务器端的NodeJS,NodeJS再发起HTTP去请求JSP,JSP依然原样API输出JSON给NodeJS,NodeJS收到JSON后再渲染出HTML页,NodeJS直接将HTML页面flush到浏览器。

在该结构下,每种前端的界面展示逻辑由node层自己维护。如果产品经理中途想要改动界面什么的,可以由前端自己专职维护,后端无需操心。前后端各司其职,后端专注自己的业务逻辑开发,前端专注产品效果开发。

将node.js作为连接前后的中间层,得到了以下好处:

适配性提升;各个终端可以有自己的前端页面。响应速度提升;后端返回给前端的数据简单了,相应速度提升。性能得到提升;Nodo将前端需要的请求页面在内网阶段进行拼接。异步与模板统一;Node可以异步,读文件可以并行,可以使前端页面异步显示。

最后总接一下,从经典的JSP+Servlet+JavaBean的MVC时代,到SSM(Spring + SpringMVC + Mybatis)和SSH(Spring + Struts + Hibernate)的Java 框架时代,再到前端框架(KnockoutJS、AngularJS、vueJS、ReactJS)为主的MV*时代,然后是Nodejs引领的全栈时代,技术和架构一直都在进步。

虽然"基于NodeJS的全栈式开发"模式很让人兴奋,但是把基于Node的全栈开发变成一个稳定,让大家都能接受的东西还有很多路要走。

以上就是本人对前后端分离的一些学习总接,在互联网高速发展的今天。前后端分离也不是我们最终的项目框架,创新之路不会停止,无论是前后端分离模式还是其他模式,都是为了更方便得解决需求,也许在未来会有更加简单和使用的开发框架出现,学习永无止境。

标签: #jsp页面获取后端返回的数据类型是