温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
  • 忘记密码?
登录注册×
获取短信验证码
其他方式登录
点击 登录注册 即表示同意 《亿速云用户服务条款》
  • 服务器
  • 数据库
  • 开发技术
  • 网络安全
  • 互联网科技
登 录 注册有礼
最新更新 网站标签 地图导航
产品
  • 首页 > 
  • 教程 > 
  • 开发技术 > 
  • web开发 > 
  • 如何写好后端API接口

如何写好后端API接口

发布时间:2021-10-23 17:55:04 来源:亿速云 阅读:487 作者:iii 栏目: web开发

这篇文章主要讲解了“如何写好后端API接口”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“如何写好后端API接口”吧!

接口交互

前端和后端进行交互,前端按照约定请求 URL 路径,并传入相关参数,后端 服务器接收请求,进行业务处理,返回数据给前端。

针对 URL 路径的 restful 风格,以及传入参数的公共请求头的要求(如:app_version,api_version,device  等),这里我就不介绍了,小伙伴们可以自行去了解,也比较简单。

我着重介绍一下后端服务器如何实现把数据返回给前端?

返回格式

后端返回给前端我们一般用 JSON 体方式,定义如下:

{     #返回状态码     code:integer,            #返回信息描述     message:string,     #返回值     data:object }

①CODE 状态码

Code 返回状态码,一般小伙伴们是在开发的时候需要什么,就添加什么。

如接口要返回用户权限异常,我们加一个状态码为 101 吧,下一次又要加一个数据参数异常,就加一个 102  的状态码。这样虽然能够照常满足业务,但状态码太凌乱了。

我们应该可以参考 HTTP 请求返回的状态码,下面是常见的 HTTP 状态码:

200 - 请求成功 301 - 资源(网页等)被永久转移到其它URL 404 - 请求的资源(网页等)不存在 500 - 内部服务器错误

如何写好后端API接口

我们可以参考这样的设计,这样的好处就把错误类型归类到某个区间内,如果区间不够,可以设计成 4 位数。

#1000~1999 区间表示参数错误 #2000~2999 区间表示用户错误 #3000~3999 区间表示接口异常

这样前端开发人员在得到返回值后,根据状态码就可以知道,大概什么错误,再根据 Message 相关的信息描述,可以快速定位。

②Message

这个字段相对理解比较简单,就是发生错误时,如何友好的进行提示。一般的设计是和 Code 状态码一起设计,如:

如何写好后端API接口

再在枚举中定义,状态码:

如何写好后端API接口

状态码和信息就会一一对应,比较好维护。

③Data

返回数据体,JSON 格式,根据不同的业务又不同的 JSON 体。

我们要设计一个返回体类 Result:

如何写好后端API接口

控制层 Controller

我们会在 Controller 层处理业务请求,并返回给前端,以 Order 订单为例:

如何写好后端API接口

我们看到在获得 Order 对象之后,我们是用的 Result 构造方法进行包装赋值,然后进行返回。

小伙伴们有没有发现,构造方法这样的包装是不是很麻烦,我们可以优化一下。

美观优化

我们可以在 Result 类中,加入静态方法,一看就懂:

如何写好后端API接口

那我们来改造一下 Controller:

如何写好后端API接口

代码是不是比较简洁了,也美观了。

优雅优化

上面我们看到在 Result 类中增加了静态方法,使得业务处理代码简洁了。

但小伙伴们有没有发现这样有几个问题:

  • 每个方法的返回都是 Result 封装对象,没有业务含义。

  • 在业务代码中,成功的时候我们调用 Result.success,异常错误调用 Result.failure。是不是很多余。

  • 上面的代码,判断 id 是否为 null,其实我们可以使用 hibernate validate 做校验,没有必要在方法体中做判断。

我们最好的方式直接返回真实业务对象,最好不要改变之前的业务方式,如下图:

如何写好后端API接口

这个和我们平时的代码是一样的,非常直观,直接返回 order 对象,这样是不是很完美。那实现方案是什么呢?

实现方案

小伙伴们怎么去实现是不是有点思路,在这个过程中,我们需要做几个事情:

  • 定义一个注解 @ResponseResult,表示这个接口返回的值需要包装一下。

  • 拦截请求,判断此请求是否需要被 @ResponseResult 注解。

  • 核心步骤就是实现接口 ResponseBodyAdvice 和 @ControllerAdvice,判断是否需要包装返回值,如果需要,就把  Controller 接口的返回值进行重写。

①注解类

用来标记方法的返回值,是否需要包装:

如何写好后端API接口

②拦截器

拦截请求,是否此请求返回的值需要包装,其实就是运行的时候,解析 @ResponseResult 注解。

如何写好后端API接口

此代码核心思想,就是获取此请求,是否需要返回值包装,设置一个属性标记。

③重写返回体

如何写好后端API接口

上面代码就是判断是否需要返回值包装,如果需要就直接包装。这里我们只处理了正常成功的包装,如果方法体报异常怎么办?

处理异常也比较简单,只要判断  body 是否为异常类。

如何写好后端API接口

怎么做全局的异常处理,篇幅原因,老顾这里就不做介绍了,只要思路理清楚了,自行改造就行。

④重写 Controller

如何写好后端API接口

在控制器类上或者方法体上加上 @ResponseResult 注解,这样就 OK 了,简单吧。到此返回的设计思路完成,是不是又简洁,又优雅。

感谢各位的阅读,以上就是“如何写好后端API接口”的内容了,经过本文的学习后,相信大家对如何写好后端API接口这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是亿速云,小编将为大家推送更多相关知识点的文章,欢迎关注!

向AI问一下细节
推荐阅读:
  1. python 如何写好main函数
  2. SpringBoot前后端分离API接口怎么保证API接口的安全性?

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

api
  • 上一篇新闻:
    Java Socket通信Flash编程代码怎么写
  • 下一篇新闻:
    设计模式之如何掌握责任链

猜你喜欢

  • 云南服务器租用有哪些优缺点
  • 法国代理服务器ip免费使用的方法是什么
  • 重庆双线服务器托管租用哪家好
  • 买了云享主机怎么使用
  • 企业私有云解决方案怎么搭建
  • 外国域名购买怎么选择注册商
  • asp建站系统怎么搭建
  • 服务器域名解析怎么解决
  • asp虚拟空间使用要注意哪些事项
  • 使用asp虚拟空间有哪些好处
最新资讯
  • 如何在Elixir中使用广播通知系统组件
  • 如何在Elixir中实现基于角色的访问控制
  • Elixir与其他函数式编程语言相比有哪些独特的特性
  • 如何在Elixir中实现乐观锁定机制
  • Elixir应用的内存优化技巧有哪些
  • 在Elixir中如何结合使用OTP和WebSockets构建实时应用
  • Elixir的宏系统有哪些高级用法
  • 如何在Elixir中优化长轮询
  • Elixir中的错误日志管理最佳实践是什么
  • 如何在Elixir中处理大规模并发连接
相关推荐
  • 怎么写好mysql检查约束
  • 怎么写好JavaScript
  • python编写好代码的
  • 怎么写好的Python代码
  • 如何写好shell脚本
  • 怎么写好SQL
  • 怎么写好java递归函数
  • 如何写好JavaScript条件语句
  • 怎么写好Python的Lambda函数
  • thinkphp6怎么搭建后端api接口

相关标签

apidoc apiserver isapi api接口 webapi restful api zabbix api apicloud javaapi webapi分页 fastapi win32api stream api web api java api datapipeline 新浪短网址api fileapi capitalize wapi
AI

深圳SEO优化公司丹竹头关键词按天计费布吉网站定制福永网站优化推广南山营销型网站建设福田百度爱采购宝安百度爱采购民治百度竞价爱联网站排名优化沙井百度爱采购深圳优化荷坳模板网站建设坪山网络广告推广坪地网站优化按天收费南联百度竞价包年推广龙华英文网站建设横岗百度网站优化排名松岗网站开发布吉建网站民治网站优化按天收费丹竹头模板网站建设南山网站定制沙井关键词按天计费大芬网站推广方案西乡优化吉祥企业网站改版布吉百度竞价包年推广龙岗网站设计模板龙岗网站优化软件大运模板制作广州标王歼20紧急升空逼退外机英媒称团队夜以继日筹划王妃复出草木蔓发 春山在望成都发生巨响 当地回应60岁老人炒菠菜未焯水致肾病恶化男子涉嫌走私被判11年却一天牢没坐劳斯莱斯右转逼停直行车网传落水者说“没让你救”系谣言广东通报13岁男孩性侵女童不予立案贵州小伙回应在美国卖三蹦子火了淀粉肠小王子日销售额涨超10倍有个姐真把千机伞做出来了近3万元金手镯仅含足金十克呼北高速交通事故已致14人死亡杨洋拄拐现身医院国产伟哥去年销售近13亿男子给前妻转账 现任妻子起诉要回新基金只募集到26元还是员工自购男孩疑遭霸凌 家长讨说法被踢出群充个话费竟沦为间接洗钱工具新的一天从800个哈欠开始单亲妈妈陷入热恋 14岁儿子报警#春分立蛋大挑战#中国投资客涌入日本东京买房两大学生合买彩票中奖一人不认账新加坡主帅:唯一目标击败中国队月嫂回应掌掴婴儿是在赶虫子19岁小伙救下5人后溺亡 多方发声清明节放假3天调休1天张家界的山上“长”满了韩国人?开封王婆为何火了主播靠辱骂母亲走红被批捕封号代拍被何赛飞拿着魔杖追着打阿根廷将发行1万与2万面值的纸币库克现身上海为江西彩礼“减负”的“试婚人”因自嘲式简历走红的教授更新简介殡仪馆花卉高于市场价3倍还重复用网友称在豆瓣酱里吃出老鼠头315晚会后胖东来又人满为患了网友建议重庆地铁不准乘客携带菜筐特朗普谈“凯特王妃P图照”罗斯否认插足凯特王妃婚姻青海通报栏杆断裂小学生跌落住进ICU恒大被罚41.75亿到底怎么缴湖南一县政协主席疑涉刑案被控制茶百道就改标签日期致歉王树国3次鞠躬告别西交大师生张立群任西安交通大学校长杨倩无缘巴黎奥运

深圳SEO优化公司 XML地图 TXT地图 虚拟主机 SEO 网站制作 网站优化