Java开发业务接口规范

简介: 规范点 说明 推荐方式 等级 文档唯一性 文档出处来源(人员和设备)必须统一,建议文档服务器,统一发布人。   重要 接口环境 要明确给出各个环境的调用地址。
规范点 说明 推荐方式 等级
文档唯一性 文档出处来源(人员和设备)必须统一,建议文档服务器,统一发布人。   重要
接口环境 要明确给出各个环境的调用地址。   重要
接口文档版本

必须有版本编号,名称+版本,版本必须能区分历史版本。

RPC facade版本号不能使用SNAPSHOT版本结尾。

  非常重要
接口兼容 必须说明是否兼容历史版本,如不兼容,必须特别说明或提供平滑迁移方案。 兼容 非常重要
安全设计 必须符合安全部门要求规范。对外接口必须已HTTPS请求提供,需要使用国家授权的发证机构进行证书签发,用来进行签名和重要信息加密。严禁私发证书,严禁商户私钥证书落地(必须商户通过浏览器申请后自行导出)   非常重要
接口调用范围 明确接口是给谁调用的(IP白名单),可接受的范围区间(同交换机、同机房、跨专线和机房等)。   重要
接口设计

接口尽量建议一个接口做一件事。

不建议将一些关键字段开放参数来传递表明接口不同业务(特别是组合字段)。

不建议使用类型的默认值作为字段的业务说明。

  1. 字符类型空或null。
  2. 数字类型的0。
  非常重要
接口接入支持开发语言 Java、Python、PHP等。

 

重要
同步接口协议 对外(https)对内(http/https/RPC)。   重要
异步接口协议

json 或 Java序列化。

json采用小写+“_”来表示key命名,最好指定解析json的包和版本。

json

fastjson

非常重要
接口编码 UTF-8、GBK、或其他特殊指定编码。 UTF-8 非常重要
接口响应时间(MS) 95%以上的平均响应时间为多少毫秒,最大响应时间为多少毫秒,平均响应时间为多少毫秒。   重要
接口最大吞吐量(TPS) 接口每秒请求事务数。   重要
接口超时时间 内部100MS之内,外部5秒之内,根据实际情况调整。   非常重要
接口重试次数

接口允许在指定超时时间内重试次数。

一般重试次数为接口平均响应时间3-5次(具体按业务情况)。

  非常重要
接口限流策略 http协议必须提供限制失败影响状态码和响应页面,RPC必须指定返回错误异常类型。   重要
接口输入参数限制

必须指明那些参数需要客户端验证(客户端不验证的,一般是服务端验证经常变更的),哪些服务端会验证。

输入参数中应包含接口请求时间和全局流水号。

字符、数字,最大最小建议使用闭区间,最大输入字段以业务为准(切记不要全量开放数据库字段限制,以后扩展就非常困难)。

日期明确指定格式。

枚举必须提供字典表。

  非常重要
接口返回参数限制

返回结果必须有终态说明(提供逻辑表,表明业务F、S),不能有模糊区间。

枚举必须提供字典表。

字符、数字,必须提供大小,建议使用闭区间。

日期明确指定格式。

RPC对象返回结果代码中严重使用extends对象,防止变动影响范围无法控制。

返回值中尽量不要返回可选字段(可有可无的)。

Mock返回必须要特殊注明。

  非常重要
代码示例

接口调用方必须提供代码示例。

http可以采用swagger。

RPC需要提供主流client语言支持,如java,其他语言如不支持,需要提供解决方法。

  非常重要

 

3. 文档示例

接口名称:XXX名称

版本:V1.0.1

接口用途:XXX

调用场景:支付XXX

是否申请白名单:是/否

签名方式:SHA256

协议:HTTP/HTTPS/RPC

支持接入语言:Java

编码:UTF-8

吞吐量:300 TPS

平均超时时间:50MS

建议重试次数:50MS/1次,3次

限流策略:300 TPS以上,强制返回XXXException,需要客户端代码处理。或 HTTP 状态码6XX,限流返回页面http://XXX,文字说明。

特殊说明:XXX

同步接口输入

名称 字段 类型 说明 客户端必须验证
         

同步接口返回

名称 字段 类型 说明
       

异步队列名称

XXX

异步返回

JSON

返回逻辑表

字段逻辑 终态 说明
     

字典表

枚举列表 说明
     

示例代码

Json:示例

其他:代码示例(各种语言示例)

客户端SDK提供示例。

4. 接口开发注意点

1、  客户端验证(基本验证,防止服务端过多通讯)
2、  服务端验证(验证顺序要考虑:如开户接口,应该先验证基础参数,非空字段长度等;再验证数据库访问,如商户是否存在;最后验证外面请求,实名认证等。避免非法数据对数据库和远程调用造成开销)
3、  事务标签,@Transactional下的代码应该行数最小,不包含数据准备、逻辑计算,尽量避免远程调用,慢查询。(将数据准备、逻辑计算排除在事务标签之外,外部请求更不能放在事务中,考虑二阶段事务和事务补偿)
4、  慢SQL(解决方式:正确SQL写法、执行计划 、索引、缓存、冗余字段、表分区、归档、分库分表等等)
5、  严禁循环内SQL执行, 连接池尽量还是要设置的少并且合理,一般5-15个左右,就能承载300-400个并发的,再上去宁愿加实例,也不太建议另外开大连接换取高并发,大连接在请求有尖值的时候,大量回收不可预估。
目录
相关文章
|
6天前
|
缓存 算法 Java
【Java引用规范】强软引用
本文详细介绍了Java中引用的概念和作用,包括强引用、软引用、弱引用和虚引用,并探讨了不同引用类型在内存管理和垃圾回收中的特性与用途。强引用是最常见的引用类型,对象只要被引用就不会被垃圾回收;软引用适用于内存敏感的缓存场景,在内存不足时会被回收;弱引用在更早的垃圾回收阶段被清除;虚引用主要用于对象的finalize过程。文章通过示例代码和内存分析工具展示了软引用的具体应用和回收机制。
【Java引用规范】强软引用
|
3天前
|
Java 数据库连接 数据库
Java服务提供接口(SPI)的设计与应用剖析
Java SPI提供了一种优雅的服务扩展和动态加载机制,使得Java应用程序可以轻松地扩展功能和替换组件。通过合理的设计与应用,SPI可以大大增强Java应用的灵活性和可扩展性。
23 11
|
4天前
|
Java API 开发者
Java 注释规范
Java中的注释规范包括单行注释(`//`)、多行注释(`/* ... */`)和文档注释(`/** ... */`)。单行注释适用于简短说明,多行注释用于较长描述,文档注释则专为自动生成API文档设计。注释应清晰明了、及时更新,避免冗余,并详细说明参数和返回值。遵循这些规范有助于提高代码的可读性和可维护性。
|
8天前
|
数据采集 Java 数据挖掘
Java IO异常处理:在Web爬虫开发中的实践
Java IO异常处理:在Web爬虫开发中的实践
|
10天前
|
数据采集 存储 前端开发
Java爬虫开发:Jsoup库在图片URL提取中的实战应用
Java爬虫开发:Jsoup库在图片URL提取中的实战应用
|
14天前
|
存储 搜索推荐 Java
探索安卓开发中的自定义视图:打造个性化UI组件Java中的异常处理:从基础到高级
【8月更文挑战第29天】在安卓应用的海洋中,一个独特的用户界面(UI)能让应用脱颖而出。自定义视图是实现这一目标的强大工具。本文将通过一个简单的自定义计数器视图示例,展示如何从零开始创建一个具有独特风格和功能的安卓UI组件,并讨论在此过程中涉及的设计原则、性能优化和兼容性问题。准备好让你的应用与众不同了吗?让我们开始吧!
|
10天前
|
Java
盘点java8 stream中隐藏的函数式接口
`shigen`是一位坚持更新文章的博客作者,记录成长历程,分享认知见解,留住感动瞬间。本文介绍了函数式接口的概念及其在Java中的应用,包括`Comparator`、`Runnable`、`Callable`等常见接口,并详细讲解了`Function`、`Predicate`、`Consumer`、`Supplier`和`Comparator`等函数式接口的使用方法及应用场景,展示了如何利用这些接口简化代码并提高编程效率。**个人IP:shigen**,与shigen一起,每天进步一点点!
24 0
盘点java8 stream中隐藏的函数式接口
|
12天前
|
Java 编译器 开发者
Java中的Lambda表达式与函数式接口
【8月更文挑战第31天】本文将深入探讨Java 8中引入的Lambda表达式和函数式接口,它们如何改变我们编写代码的方式。通过简化集合操作、事件处理等示例,我们将看到这些特性如何提升代码可读性、减少冗余,并提高开发效率。准备好一起探索这个让Java编程更加简洁强大的新世界吧!
|
13天前
|
Java 开发者
Java 编程风格与规范:跟上时代热点,打造高质量代码,为开发者梦想保驾护航
【8月更文挑战第30天】本文强调了Java编程中代码质量和可维护性的重要性,详细介绍了命名规范、代码格式和注释的最佳实践,如使用描述性的命名、适当的缩进及空行,以及关键代码部分的注释说明,同时还提供了避免魔法值和减少代码重复的建议与示例,帮助提升团队协作效率和项目长期发展。
32 2
|
12天前
|
Java
编写规范JAVA代码
本文档制定了Java编程规范,旨在确保系统源程序的可读性和可维护性,适用于所有Java开发、测试及维护过程。规范包括命名规则(如Package、Class及其成员等)与样式规定,强调统一风格以提高协作效率,并列举了具体示例与注意事项,如避免单字符变量名及使用有意义的反义词组命名等。
31 1