百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术文章 > 正文

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

ccwgpt 2024-10-24 09:22 30 浏览 0 评论

前后端是怎么分离的

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

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

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

  1. Web服务器:一般指像Nginx,Apache这类的服务器,他们一般只能解析静态资源。
  2. 应用服务器:一般指像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的开发,不依赖于后端。

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

  1. JS存在大量冗余,在业务复杂的情况下,页面的渲染部分的代码,非常复杂。
  2. 在Json返回的数据量比较大的情况下,渲染的十分缓慢,会出现页面卡顿的情况
  3. 资源消耗严重,在业务复杂的情况下,一个页面可能要发起多次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作为连接前后的中间层,得到了以下好处:

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

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

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

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

相关推荐

FastUI:用Python构建高性能React应用,告别JavaScript

在现代Web开发中,前后端分离已经成为主流趋势。然而,前端开发往往需要深入掌握JavaScript和各种框架,这对于许多Python开发者来说是一个不小的挑战。今天,我们要介绍一个革命性的UI框架——...

Python + Flet 开发网站的最佳数据库模块组合

对于使用Python和Flet开发网站并需要数据库支持的应用,以下是推荐的模块组合方案。方案一:SQLite+SQLAlchemy(推荐轻量级方案)**适用场景**:中小型应用、单用户或...

前端程序员应该往全栈方向发展吗?还是坚守前端?

这是一个非常经典且重要的问题,几乎每一位走到职业生涯十字路口的前端程序员都会思考。它没有一个绝对的“正确答案”,但我们可以从多个维度来分析,帮你找到最适合你的那条路。简单来说,这不是一个“要不要”的...

Python交互仪表盘工具:Panel 进阶学习路线图

Panel作为Python生态系统中最强大的交互式仪表盘工具之一,其学习曲线既平缓又深远。这里我将为您构建一个系统化的进阶学习框架,包含实战项目和关键学习节点。1.现代化Web集成开发1....

PuePy:将Python带入浏览器的革命性框架

在现代网络开发中,JavaScript无疑是主导地位的编程语言。但最近,随着WebAssembly和PyScript的崛起,Python的使用场景逐渐扩展到了前端开发领域。PuePy应运而生,作为一...

不容易!找到一个python的超简易网站搭建神器

作者:清香客来源:Python技术相信很多学习python的酱友们,大部分和我一样是为了提升工作效率,但是在提升自己的工作效率时,也会想着做同样工作的同事能不能也用上自己写的脚本(视工作环境而定)...

PyWebView:用 Python 构建桌面应用的神器

作为一个Python开发者,我一直希望能找到一种简便的方法来构建桌面应用,而不是去学习诸如Electron这种重度依赖JavaScript的技术栈。就在我为桌面应用开发寻找替代方案时,遇到...

Python Django框架中级教程:深入探索Django的核心功能

在Python的Web开发领域中,Django框架以其强大的功能和高效的开发模式占据着重要地位。对于已经掌握了Django基础的开发者来说,进一步深入学习中级知识能让我们开发出更复杂、更强大的Web应...

【Python程序开发系列】使用Flask实现前后端分离(案例)

这是我的第398篇原创文章。一、引言随着web开发的不断发展,前后端分离已成为越来越流行的架构设计。Flask是一个轻量级的Pythonweb框架,非常适合用于构建API,然后配合前端框...

每天一个Python库:Flask超轻量Web框架,灵活高效!

为什么要学Flask?Flask是一个「微型但强大的」Web框架:极简上手,几行代码即可跑起来灵活扩展,想加啥加啥(RESTful、JWT、数据库…)文档齐全,适合入门API开发或快...

Python个人量化投资系统:后台搭建

独立搞量化系统的程序员最烦啥?重复造权限管理的轮子绝对排前三。技术老手用Python+PearAdminFlask两天搭出量化后台,实测开源框架真能省下80%基础工作量。开源后台框架选对,一人项目...

python后端学什么(python后端好找工作吗)

在当今数字化的时代,Python后端开发成为了众多开发者追逐的热门领域。那么,想要在这个领域崭露头角,我们究竟应该学些什么呢?学习Python后端开发需要掌握全栈技术栈,涵盖从基础语法到分布式...

Motia:重新定义后端与智能体整合的未来平台

在AIagent技术飞速发展的今天,我们拥有了诸如Dify、RAGFlow、LangChain等一系列优秀平台。然而,随着场景复杂度增加,开发者正面临一个共同问题:后端越来越碎片化,Agen...

Python数据校验不再难:Pydantic库的工程化实践指南

在FastAPI框架横扫Python后端开发领域的今天,其默认集成的Pydantic库正成为处理数据验证的黄金标准。这个看似简单的库究竟隐藏着哪些让开发者爱不释手的能力?本文将通过真实项目案例,带您解...

Python Flask 建站框架实操教程(flask框架网页)

下面我将带您从零开始构建一个完整的Flask网站,包含用户认证、数据库操作和前端模板等核心功能。##第一部分:基础项目搭建###1.创建项目环境```bash#创建项目目录mkdirfl...

取消回复欢迎 发表评论: