后端开发:如何写出可靠的接口

后端开发:如何写出可靠的接口

毕业进入现在的公司已近一年,完整参与了部门新项目两期的开发上线过程,作为一名后端开发,觉得最痛苦的是上线前和上线后的改 bug 阶段,面对各种突如其来、莫名其妙的bug,头昏脑涨、手忙脚乱、越改越懵,经常导致实验式改 bug、改一个 bug 又出现俩 bug 的之类的惨剧,我就忍不住想,为什么每次上线前都会有这么多bug呢?

前几天还读到一篇豆瓣文章,没有总结的就不是经验,只是经历。程序员也不能业务来了就写代码,有bug了就改bug,这样技术很难提升,也就难怪每次都会有那么多bug了。有的开发人员工作多年,接口还是时不时500,前期忙着写代码,后期忙着改bug,心累。

我从一期熟悉业务、框架,写一写边缘接口,到二期负责一个小模块,尝试数据库、程序的设计,中间磕磕绊绊,昨天也顺利上线,模模糊糊也感觉到了一些经验,于是努力总结下,虽然简单,也许能给自己和读者一些启发。(本文只针对初级水平,简单的bug,不涉及高并发、海量数据等复杂问题)

一. 接口为什么出bug?

辛辛苦苦写的接口,自己测的时候好好的,怎么别人一调就出错了呢??(此处应有表情包,请自行脑补)当然可能是运行环境的问题,不过程序统一部署在服务器上,这一般是架构师或者运维负责的工作,至于编程语言或者操作系统的问题,也通通不在今天考虑范围内,今天,我们只考虑自己写出的bug。

事实上,运行中的程序所涉及的,无非三样:资源(cpu、内存等)+ 算法(程序运行流程)+ 数据(用户输入、数据库、第三方接口等)。通常我们认为资源是可靠的,出现bug主要是由于算法的不可靠或者数据的异常。

更进一步,机器严格按照0/1执行指令,算法上一次执行正常,为什么这一次会失败?本质上还是因为数据变了,而算法没能覆盖此情况,因此,要想保证接口的稳定,主要从两方面考虑:保证数据的可靠性、算法的健壮性,而算法的健壮性也就是考虑到数据的各种情况,两者密不可分。

二. 如何写出bug更少的接口?

如前分析,数据的变化是接口bug最常见、本质的原因。而其中,用户输入又是数据变化最主要的原因。而程序必然要有用户输入,否则毫无意义。

编程界有句名言:永远不要相信用户输入。你永远不知道,用户会在一个期待姓名的输入框里都输入些什么。不要因为前端做了过滤你就放心,一方面是用户可能会使用爬虫等手段直接访问你的接口,另一方面,前端也是你的用户,沟通也存在误差,前端可能会使用错误的方式调用你的接口,而这种错误可能会更加隐蔽。

第一条建议:严格校验用户的输入,包括格式、内容。

我知道很多人都懒得去逐条检验用户输入,觉得只要功能正常就ok了,但是,这经常会导致后期改bug时投入更多的经历。经常测试提了bug,你查来查去,发现是前端传错了参数,或者没有合理限制用户输入,当然你可以很刚,让前端去改,但这个过程已经浪费了你大量的时间精力,还不如一开始自己做好检验,返回合适的错误消息,会为你后期节省大量的精力。

对于PHP等动态语言,尤其如此,例如我们使用Laravel框架,我会在所有接口入口处,首先使用$request->validate()检验所有输入数据的格式,如有必要,还会写代码进一步校验输入内容,比如时间范围、请求数据是否有效等等。

第二条建议:考虑用户的骚操作,重复提交、延时提交

重复提交应该是大多数后端都能想到的情况,也就是接口的幂等性,有些资源只能操作一次,必须进行校验,其实不仅是重复提交,还包括同一事件被两人重复处理的情况。

而对于延时提交,其实是测试给我提bug后我才意识到的问题模式。例如我们通过get接口返回给用户某种资源,用户可以通过post接口回传资源id并提交修改,由于是自己的get接口返回的,我们可能想着只验证id合法就行了,看似形成严格闭环,但如果用户停留在此页面延时提交,则可能在此期间资源过期,或者资源已被他人修改,而改用户也成功修改的bug。其实进一步思考,你会发现,这跟高并发情景下的资源失效有异曲同工之处。

知网AI智能写作 知网AI智能写作

知网AI智能写作,写文档、写报告如此简单

知网AI智能写作 38 查看详情 知网AI智能写作

第三条建议:检验数据库、第三方接口的返回数据

除了用户输入,常见的数据来源还有数据库、第三方接口。相对而言,这些数据接口会可靠的多,而且内容格式也更规范。不过为了接口的稳定性,最好也做一些检验。如常见的数据为空的情况,就要及时中止程序执行并抛出合适的信息。

对了,对于数据库,我还遇到过bug,就是主从延迟导致的数据更新问题,由于经验尚浅,这类问题不很擅长,就不再写。

第四条建议:程序算法尽可能覆盖异常情况

这条实际上是对前三条的补充,有些不合法的用户输入你可以直接中止程序并返回错误信息,但有些情况可能需要程序继续运行,进行特殊处理,这些情况你在程序设计之初应该尽量考虑周全,后期bug会少很多,也更容易维护。

三. 如何写出更高效的接口

最后,再写一点点关于关于接口效率、代码质量的思考。

1. 影响接口效率的主要是数据库操作
以我有限的经历来看,接口耗时长基本都是因为数据库操作不合理,我们大多数的业务代码并不会有性能问题。我见过不少在for循环里查询数据库的代码,一定要避免,我们可以先一次性取出所有数据,然后逐个去处理。例如我们会在框架层记录所有数据库操作,调试接口时即可看到所有数据库操作以及相应耗时,该合并的查询要合并,该优化的耗时查询相应去优化。

2. 合理使用Exception,日志

这条主要针对php语言,由于历史原因,我看到不少代码靠return中止程序并传递错误信息,这样在代码复杂、调用层次深了以后极难维护,远没有Exception机制直观方便。还有,重要信息一定要写日志,便于后期发现问题及调试,也可用来自证清白。

3. 代码要合理划分、抽象

不要复制粘贴代码,重复的功能要独立出来;设计时要合理考虑需求变更、扩展;写小而专注的函数,不要把复杂功能一坨实现;这样写的代码才易于修改、测试以及扩展。这块我做的也不好,上线后看自己的代码都是一坨一坨,难以维护,接下来还要多思考,多实践。

四. 结束语

祝大家写的代码都没有bug!

更多Laravel相关技术文章,请访问Laravel教程栏目进行学习!

以上就是后端开发:如何写出可靠的接口的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/214136.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年11月3日 14:06:25
下一篇 2025年11月3日 14:12:03

相关推荐

  • 利用Formspree为网站集成简易消息系统教程

    本教程旨在指导开发者如何在网站中集成一个简易的消息或邮件系统,以实现用户与管理员之间的单向通信。针对小型项目和有限用户群体的需求,文章将详细介绍如何利用Formspree服务结合简单的HTML表单,无需复杂的后端开发,即可快速构建一个功能性的站内消息提交方案,有效避免了直接嵌入完整邮件客户端的复杂性…

    2025年12月23日
    000
  • 构建轻量级网站内部消息系统:Formspree 集成指南

    本文旨在探讨如何在网站中为少量内部用户构建一个轻量级的消息系统,避免直接嵌入复杂的邮件客户端。我们将介绍如何利用 Formspree 结合简单的 HTML 表单,实现用户向管理员发送邮件消息的功能,从而满足网站内部通信需求,提供一个便捷、高效且易于实施的解决方案。 引言:网站内部消息系统的需求与挑战…

    2025年12月23日
    000
  • 深入解析HTML表单中value与name属性的机制与应用

    本文旨在深入探讨html表单中`input`文本框和`select`下拉菜单的`value`与`name`属性。我们将阐明为何文本输入框的`value`属性常被省略而由用户动态填充,以及`name`属性在表单数据提交至服务器时的核心作用。同时,文章还将区分`value`和`placeholder`的…

    2025年12月23日
    000
  • 使用Thymeleaf自然模板优化Spring Boot前后端协作流程

    本文探讨了在Spring Boot应用中,如何利用Thymeleaf的自然模板特性,高效地协调前端设计与后端开发工作。通过允许HTML文件同时作为静态设计稿和动态渲染模板,开发者可以避免重复修改,实现前端设计师与后端工程师之间的无缝协作,确保布局和样式更新的顺畅进行。 引言:前后端协作的挑战 在基于…

    2025年12月23日
    000
  • 使用JavaScript构建高效客户端搜索栏:基于DOM操作的页面内容筛选

    本教程将指导您如何使用纯javascript实现客户端页面内容搜索功能。通过获取用户输入,并遍历页面上已渲染的dom元素,根据匹配结果动态调整元素的显示状态,从而在无需重新加载或重新渲染数据的情况下,快速筛选和展示相关内容,显著提升用户体验和页面响应速度。 在现代Web应用中,为用户提供快速、响应式…

    2025年12月23日 好文分享
    000
  • HTML语言属性怎么设置_网页语言声明可访问性重要性

    务必设置HTML语言属性,这是提升网页可访问性、SEO和多语言支持的基础。通过在中声明主语言,并在局部元素上使用lang属性标识不同语种内容,能确保屏幕阅读器正确发音、搜索引擎准确索引、翻译工具精准识别,从而保障视障用户的信息获取,优化全球用户的浏览体验,尤其在多语言网站中更需系统化管理语言声明。 …

    2025年12月22日
    000
  • JavaScript中利用Haversine公式计算地理点序列间距离

    本教程详细介绍了如何在JavaScript中,使用Haversine公式计算地理位置点数组中连续点之间的距离。通过迭代数组,比较相邻点的经纬度,实现精确的公里级距离测量,并提供了完整的代码示例及注意事项。 引言:地理点序列距离计算 在地理信息系统(GIS)、路径规划或位置服务等应用中,我们经常需要处…

    2025年12月22日
    000
  • 如何创建HTML中的无序列表

    无序列表在网页设计中用于提升内容可读性与信息架构,常用于导航菜单、产品特性、FAQ等场景,通过和标签构建,支持嵌套实现层级结构,并可用CSS自定义样式如符号类型、图片项目符及伪元素装饰,增强视觉表现与用户体验。 在HTML中创建无序列表其实非常直接,你只需要用到 (unordered list)和 …

    2025年12月22日
    000
  • 前端和后端开发的区别及联系

    前端和后端开发是构建一个完整网络应用所必不可少的两个方面,它们之间有着明显的区别,但又密切联系在一起。本文将分析前端和后端开发的区别及联系。 首先,我们来看一下前端开发和后端开发的具体定义和任务。前端开发主要负责构建用户界面和用户交互部分,即用户在浏览器中所看到和操作的内容。前端开发人员通常使用HT…

    2025年12月22日
    000
  • 前端和后端开发在项目中的作用和协作

    在现代软件开发中,前端和后端开发起着至关重要的作用,并且二者之间的协作也至关重要。前端开发主要负责用户在浏览器中看到的界面和交互体验,而后端开发则负责处理数据、逻辑和与数据库的交互。两者密切合作,共同完成一个项目的搭建与实施。 首先,让我们来看一下前端开发在项目中的作用。前端开发是网站或应用的门面,…

    2025年12月22日
    000
  • 了解API: 探索不同类型的接口及其用途

    了解API: 探索不同类型的接口及其用途,需要具体代码示例 导言:在如今的数字化时代,我们经常听到与API(应用程序接口)相关的词汇。API是现代软件开发中不可或缺的一部分,它提供了各种方式让不同的软件系统之间进行通信和交互。本文将向读者介绍不同类型的API,并提供具体的代码示例来加深对API的理解…

    2025年12月21日
    000
  • JavaScript数组分块:将一维数组转换为指定宽度子数组的二维数组

    本文深入探讨了JavaScript中将一维数组按照指定宽度转换为二维数组(即数组分块或Chunking)的技术。我们将解析这一常见操作的原理、应用场景,并通过分析流行的Lodash库中的`chunk`函数实现,以及提供一个简洁的纯JavaScript实现,帮助开发者理解并掌握高效、健壮的数组分块方法…

    2025年12月21日
    000
  • JavaScript算法实现_javascript编程挑战

    数组去重:利用Set特性去除重复元素,return […new Set(arr)];2. 回文判断:转小写后与反转字符串比较,cleaned === cleaned.split(”).reverse().join(”);3. 快速排序:选基准值分治递归,left、…

    2025年12月21日
    000
  • 数组分块(Chunking)技术详解:按指定宽度拆分数组为子数组

    数组分块(Chunking)是一种将一个大型数组按照指定宽度拆分为多个小型子数组的常用操作。这种技术在数据处理、分页显示、批量操作等场景中非常实用,能够有效管理和处理数据集合。本文将深入探讨数组分块的概念、实现原理,并提供专业的代码示例,帮助读者理解并掌握这一高效的数据处理方法。 数组分块(Chun…

    2025年12月21日
    000
  • React Hook Form数据转换:优化提交时空字符串到Null的处理策略

    本教程深入探讨在React Hook Form中,如何高效且可靠地将表单提交数据中的空字符串值转换为`null`。我们将分析在`onSubmit`处理器中直接使用`setValue`进行批量字段更新可能存在的局限性,并重点介绍一种推荐的、通过直接操作数据对象进行预处理的策略,确保数据在发送到后端AP…

    2025年12月21日
    000
  • javascript_算法在JS中的实现

    JavaScript支持多种算法实现,排序算法如冒泡排序通过相邻元素交换实现升序排列,快速排序采用分治法递归分割数组;查找算法中二分查找适用于有序数组,通过比较中间值缩小范围。 JavaScript 是一门功能强大的编程语言,广泛应用于前端和后端开发。它同样适合实现各种算法,帮助我们高效解决实际问题…

    2025年12月21日
    000
  • JavaScript数据结构实现_javascript算法基础

    JavaScript中常用数据结构包括栈、链表和字典:1. 栈利用数组的push和pop实现LIFO,适用于括号匹配;2. 链表由节点组成,插入删除高效,适合频繁修改场景;3. 字典用对象实现键值对存储,常用于频率统计;4. 二分查找在有序数组中以O(log n)效率查找目标值,需数组已排序。掌握这…

    2025年12月21日
    000
  • 表单验证逻辑设计_自定义验证器的编写技巧

    自定义验证器是保障数据完整性与安全性的关键,需具备清晰逻辑、高可维护性与复用性。其核心结构包括输入参数、验证逻辑、错误消息及异步支持,如Angular中返回{[key:string]:any}|null,Yup/Joi通过test扩展规则。应将验证逻辑抽象为独立模块,采用参数化配置、规则组合与清晰命…

    2025年12月21日
    000
  • JavaScript reduce 方法实现复杂对象数组的嵌套转换与数据聚合

    本文详细阐述如何利用 JavaScript `reduce` 方法将扁平化的对象数组转换成具有多级嵌套结构的数据。通过以 `medico`、`rateio` 和 `convenio` 为键进行分组,并对 `subtotal` 值进行累加,本教程展示了 `reduce` 在复杂数据重塑和聚合场景中的强…

    2025年12月21日
    000
  • 如何检查并设置数值是否恰好包含两位小数

    本教程详细介绍了如何使用JavaScript有效验证数字输入,确保其小数部分恰好为两位。文章通过`String.prototype.split()`方法结合字符串长度判断,提供了一个清晰的解决方案,并附带了示例代码和关键注意事项,帮助开发者准确处理此类数据格式校验需求。 在前端或后端开发中,对用户输…

    2025年12月21日
    000

发表回复

登录后才能评论
关注微信