当前位置: 首页 > news >正文

web后端----后端框架基本架构、基本流程

这里写目录标题

  • 声明
  • 后端框架
    • 环境
    • 最简单的一个框架
      • 简介
      • 关于端口号
      • 关于注册路由
    • 继续扩展最简单的框架(使用MVC三层架构)
      • 以“做一个需求”为例
      • API接口设计模式(设计接口文档,如已有接口文档,可以跳过)
        • 简介
        • RESTful API
        • 本需求的API示例
      • 按照接口文档,注册上路由(controller层)
      • 处理函数的实现(server层)
      • 用数据库持久化数据(dao层)
    • 视频学习地址

声明

后端的框架都是一通百通,我们现在先了解一下一个后端框架普遍上会有什么,以及我们使用一个主流的后端框架基本上需要做哪些工作

后续会以C++框架:oatpp为主,详见下篇文章

本次教程先以js框架入手,因为代码比较简单,可以避免喧宾夺主

最好可以先去看了专栏内的:
《web后端----HTTP协议与浏览器》
《web后端----接口文档》
《web后端----三层架构》

后端框架

环境



最简单的一个框架

简介


1、首先创建了一个Express实例

2、之后指定开放的端口号

3、相当于在注册路由

4、启动服务器,并在后端控制台打印http://localhost:{port},这个是本地web后端服务根 URL

关于端口号


就是访问你web服务时,首先就要输入web服务的ip:端口号,此处由于是本机,所以使用localhost代替本机ip

他们是所有“请求资源URL”的,而他们也可以用域名代替,如www.baidu.com

关于注册路由


首先来看什么是路由

如上图1、的解释

而注册路由,就是先规定好,当收到某种**“方法+URL”时,要去哪个业务处理函数中处理后续的工作
这里要注意:
注意点1:不是仅仅一个URL,而是方法+URL
注意点2:URL指定的是
相对于“根URL”后续的路径**,如上面的/users,实际上前面会拼上http://{IP:Port},如本例中是http://localhost:8090/users


上图中,
1、注册一个根路由,即,当对方发来的是get + 根URL,后续放入哪个函数处理
当用户直接进入一个网址时,一般就是get + 根URL

而此处简化了函数处理,直接用了一个匿名函数,函数内直接返回了一个“Hello World!”

2、注册一个get+根URL/a/b的一个路由,
处理函数:返回“Hello World! 123”

继续扩展最简单的框架(使用MVC三层架构)

以“做一个需求”为例


简单分析:
其中,获取xxx,属于get请求
创建xxx,属于post请求
删除xxx,属于delete请求

API接口设计模式(设计接口文档,如已有接口文档,可以跳过)

简介

我们要为上面的每一个需求,设计一个API接口

相当于接口文档,前后端都要看,都要遵循

RESTful API


我们采用最常见的一种API风格,RESTful API,他包含两部分:资源,和,方法

其实就是URL和请求方法

跟我们之前理解的一样,但是他具体规定了URL和请求方法的设计思路



我们知道URL是请求路径,是唯一标识,但是我们并不知道怎么设计URL,现在这个规定了URL怎么设计

URL设计规则:
1、URL要以资源为中心,如下图:

接口文档中,URL设计时,要为每个资源设计一个唯一的URL,之后,操作该资源就用这个唯一的URL
如,查询所有用户,涉及到的资源是users
查询单个用户,涉及到的资源就是users/{id}
而 创建新用户,也是用users,因为id是进入数据库之后自增的
但更新用户,就需要定位到某个id

同时注意有的用get有的用post

2、URL标识层次结构和关系,上图也体现了

本需求的API示例

按照接口文档,注册上路由(controller层)


注意点1:上面的“请求方法”,体现在函数名上
注意点2:对于变量式URL,如todos/{id},要使用特殊的字符标注,本例子中的框架是**:id**,这个冒号

PS,上图中的接口只是定义了路由,还没有进行处理函数的实现

处理函数的实现(server层)

例子1:获取指定ID的todo(get)

可以看到,对URL注册了一个匿名函数,该函数进行了具体的实现:
大概就是拿到id之后,查询对应id对应的信息,封装成json,并进行返回

例子2:添加一个todo

这里也是对URL注册的函数进行一个业务实现:
1、一般post请求都会带有请求体,拿到请求体的数据:要添加的数据
2、将这个请求体要添加的数据,创建成一条记录
3、将该记录添加到数据库(此处只是先用全局数组模拟)
4、返回状态码以及一些json信息
5、这个是如果请求体中缺少“添加”所需要的不可少的数据,会返回错误的状态码以及json信息

用数据库持久化数据(dao层)

将上面server中,对数据的操作进行修改:

原本是使用全局数组,现在改为sql操作

视频学习地址

https://www.bilibili.com/video/BV1k4421Z7d2/?spm_id_from=333.1007.top_right_bar_window_history.content.click&vd_source=775f826eaffd2d6cab17e6a5cc2b9878

http://www.jsqmd.com/news/503379/

相关文章:

  • 突破音乐格式枷锁:4大维度重构NCM文件的自由转换技术
  • 3大突破!Avalonia让跨平台音频界面开发效率提升200%
  • Ubuntu 22.04 LTS下NVIDIA驱动安装避坑指南:如何用终端一键搞定(附常见错误解决)
  • Step-by-Step Guide to Installing Anolis OS 8.10 for Cloud Environments
  • Qwen3智能字幕对齐系统在在线教育场景的应用
  • X上100万浏览只赚40美元,YouTube却能赚8000美元?程序员副业出海的200倍身份跃迁指南
  • 05_Priority Queues 优先队列
  • 彻底搞懂 Java 垃圾回收(GC)
  • OpenCV实战:5分钟搞定图像模板匹配(NCC算法+C++代码详解)
  • 6.4 日志到底怎么写才有用?排障效率提升的底层方法
  • 教学实验规范下的AI审核与IACheck:让样品分析检测报告更严谨与可复核
  • 鸿蒙HarmonyOS无线调试全攻略:摆脱USB线束缚的5个关键步骤
  • HBase实战:用Python+Thrift实现电商用户行为数据存储(含Region分裂优化)
  • 别再乱用Transform了!用MONAI处理医学图像,这5个核心操作你得先搞懂
  • 别再踩坑了!Vue中使用postMessage传值的5个注意事项(含window.opener最佳实践)
  • U8g2自定义中文字库实战:从零构建Arduino OLED专属字体
  • 华为防火墙双线路故障切换避坑指南:健康检查配置常见误区解析
  • Llava-v1.6-7b模型部署教程:Linux环境一键安装指南
  • QGIS插件开发避坑指南:从安装Plugin Builder到第一个Hello World插件
  • 多语言情感分析挑战与解决方案
  • 锤子科技Android开源项目深度解析:一步与大爆炸的创新实现
  • LingBot-Depth实测分享:在RTX 4090上实现1080p深度图实时精炼
  • 6.5 Git协作不踩坑:提交规范分支策略冲突处理全流程
  • YOLOv5后处理全流程拆解:从6万个候选框到最终结果的‘过滤漏斗’
  • 探索C# WPF MVVM大屏看板3D立体可视化大屏监控源码
  • AGENTS.md 高效开发指南:3个核心操作技巧
  • Jetson Orin NX深度学习环境搭建:PyTorch与CUDA的完美结合
  • 戴森吸尘器电池复活完整指南:开源固件解锁隐藏功能
  • 2024年一级建造师通信与广电工程备考攻略:5G与广电新技术考点全解析
  • Python 实战2:新浪新闻静态 + 动态数据采集与清洗全流程