怎么样去写一个好的接口(下)?(用ThinkPHP做示例)

上面已经堆叠了很多的分析内容,这里我以一个后端工程师的角度去编写实际的数据接口代码

简单的代码示例。假设需求是(修改文章 只能修改审核中状态)

1 编写接口文档。这里我演示使用的是apifox工具,也是个人开发习惯问题。其他工具也是可以的。

选择快速请求选项

选择请求方式、填写请求地址、填写请求所需要的参数、发送请求、获取到数据。

此时点击右上角保存中的【保存为接口】。

此时,只需要在修改文档中,将字段的说明文字补充完整即可。就这么简简单单的几步就搞定了接口文档的编写工作,so easy !!!

2 接收并验证数据的合法性

arduino 复制代码
Route::resource('article','index/article');  //文章相关业务

我们其实是创建好了一个资源路由的。

php 复制代码
class Article
{
    //对文章进行修改
    public function update($id){
        
    }
}

然后在update方法中处理具体的修改业务

scss 复制代码
$param = request()->param();   //接收请求中携带的参数

假设我们不做数据验证,全凭前端进行验证。那假设前端在请求中携带了status参数。

那么,文章主状态字段被一下干废了,史诗级事故就此开始。

所以我们要提取需要的字段,并进行数据合法性验证。

php 复制代码
    //开始进行数据验证
    $validate = \think\Validate::make([
        'title' => 'require|max:40',
        'content' => 'require|max:2000'
    ]);
    if (!$validate->check($param)) {
        return json(['code'=>40001,'result'=>$validate->getError()]);
    }
    //提取合法参数
    $data = [
        'title'=>$param['title'],
        'content'=>$param['content'],
    ];

这样就保证了只能修改到我们要求修改的字段数据了。

3 使用校验通过的数据,进行下面的业务处理

只能是审核中状态 也就是 status == 1 的时候才能对数据进行修改操作。而且考虑到有多人同时提交数据修改的情况的出现。

bash 复制代码
    //判断一下当前是否为允许修改的状态
    $result = 0;
    Db::transaction(function () use (&$result,$id,$data){
        $check_data = Db::table('article')->where('id', $id)->lock(true)->find();
        if($check_data['status'] != 1){
            return json(['code'=>40001,'result'=>'当前文章非可修改状态!']);
        }
        $result = Db::table('article')->where('id', $id)->update($data);
    });

    return json(['code'=>10001,'result'=>$result]);

因为有状态限制,所以修改数据之前,对当前id数据进行查询,并判断了状态。因为有多人同时提交的情况发生,所以开启了事务并进行了锁定操作。这样就完成了数据业务的处理逻辑。

其实很多时候,业务处理这部分很复杂,需要进行很多的各种情况的判断。这里只是通过最简单的示例来演示整个开发流程

4 完成接口的自测工作

对接口完成一下简单的自测,包括两个字段都为空,字段超出等情况的处理。请求成功以后,就可以放心的把接口交给前端工程师进行接口对接了。上面业务开发中,也补充了关键位置注释,保证接口有问题时候可以随时定位问题所在。

不管是新手还是有经验的开发者,你可以会这么写但是懒得这么搞,但是不可以不会。以上内容为个人经验编写,如果有不足的地方还是希望能给我提出来

相关推荐
搬码后生仔6 分钟前
将 ASP.NET Core 应用程序的日志保存到 D 盘的文件中 (如 Serilog)
后端·asp.net
Suwg2098 分钟前
《手写Mybatis渐进式源码实践》实践笔记(第七章 SQL执行器的创建和使用)
java·数据库·笔记·后端·sql·mybatis·模板方法模式
凡人的AI工具箱1 小时前
每天40分玩转Django:Django文件上传
开发语言·数据库·后端·python·django
spcodhu1 小时前
在 Ubuntu 上搭建 MinIO 服务器
linux·后端·minio
小码编匠2 小时前
2024 年各编程语言运行百万并发任务需多少内存?
java·后端·python
sin22012 小时前
springboot测试类里注入不成功且运行报错
spring boot·后端·sqlserver
努力的小雨3 小时前
灵感上线,云开发实现抽奖转盘是多么简单的一件事
后端
kirito学长-Java3 小时前
springboot/ssm网上宠物店系统Java代码编写web宠物用品商城项目
java·spring boot·后端
海绵波波1073 小时前
flask后端开发(9):ORM模型外键+迁移ORM模型
后端·python·flask
余生H4 小时前
前端Python应用指南(二)深入Flask:理解Flask的应用结构与模块化设计
前端·后端·python·flask·全栈