这里写目录标题
- 声明
- 后端框架
声明
后端的框架都是一通百通,我们现在先了解一下一个后端框架普遍上会有什么,以及我们使用一个主流的后端框架基本上需要做哪些工作
后续会以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操作