登录
/
注册
首页
论坛
其它
首页
科技
业界
安全
程序
广播
Follow
关于
博客
发1篇日志+1圆
记录
发1条记录+2圆币
发帖说明
VIP申请
登录
/
注册
账号
自动登录
找回密码
密码
登录
立即注册
搜索
搜索
关闭
CSDN热搜
程序园
精品问答
技术交流
资源下载
本版
帖子
用户
软件
问答
教程
代码
VIP申请
VIP网盘
网盘
联系我们
道具
勋章
任务
设置
我的收藏
退出
腾讯QQ
微信登录
返回列表
首页
›
业界区
›
业界
›
开发一份API接口,需要注意这些,看你做到了几项 ...
开发一份API接口,需要注意这些,看你做到了几项
[ 复制链接 ]
眩疝诺
2025-6-6 14:08:21
在实际工作中,我们需要经常跟外部三方系统打交道,可能会提供API接口给外部三方系统调用。
API接口通常通过WebController来实现。如果设计一个优雅的API接口,能够满足安全性、稳定性、易维护等多方面需求呢?
下面几项,看你做到了哪些。
1. 数字签名
为了防止API接口中的数据被篡改,我们需要对接口做签名。签名密钥由请求方和提供方互存,不参与网络传输。
接口请求方将请求参数 + 时间戳 + 密钥拼接成一个字符串,然后通过md5等hash算法,生成一个签名sign。
然后在请求参数或者请求头中,增加sign参数,上送给API接口。
API接口的网关服务,获取到该sign值,然后用相同的请求参数 + 时间戳 + 密钥拼接成一个字符串,用相同的m5算法生成另外一个sign,对比两个sign值是否相等。
如果两个sign相等,则认为是有效请求,API接口的网关服务会将给请求转发给相应的业务系统;如果两个sign不相等,则API接口的网关服务会直接返回签名错误。
BTW,提个问题:签名中为什么要加时间戳?
答:为了安全性考虑。一来,通过不同的时间戳,可以有效减少签名相同的概率。二来,API接口的网关服务可以校验时间戳,与服务器当前时间是否吻合(实际生产中会容许几秒的差异),不吻合就直接返回非法请求。
目前生成数字签名的密钥有3种形式:
一种是双方约定一个固定值privateKey。
另一种是API接口提供方给出AK/SK两个值,双方约定用SK作为签名中的密钥。AK接口调用方作为header中的accessKey传递给API接口提供方,这样API接口提供方可以根据AK获取到SK,而生成新的sgin。
第3种是使用非对称加密算法生成签名,常见的是RSA。RSA包含一对公私钥,其中一方保留自己的私钥,并将公钥提供给另一方。调用方发起API请求时通过私钥加签,另一方则通过其公钥验签。
我们可以使用在线工具生成密钥对:https://tools.ytdevops.com/rsa-key-pair-generator
2. 敏感数据处理
有些时候,我们的API接口会直接传递非常重要的数据,比如:用户的登录密码、银行卡号、手机号、用户身份证等,将这些参数直接明文暴露到公网上是非常危险的事情,很容易造成用户隐私数据泄露。
这些用户隐私数据被称作敏感数据。那么,针对敏感数据,API设计上我们怎么做呢?
一句话:
对于交易类接口,涉及敏感数据的,做加密处理。对于非交易类接口,涉及敏感数据的,考虑做脱敏处理。
当然,还有一个原则是,
非需不返回用户隐私数据
。
敏感数据加密
数据加密通常使用对称加密算法。如AES、DES、3DES。双方互存加密秘钥encryptKey。一方利用encryptKey加密,另一方利用encryptKey解密。
当然,也可以对数据进行RSA非对称加密。调用方利用API提供方的公钥对数据加密,API提供方则利用自己的私钥对数据解密。
需要指出的是,无论是RSA加密还是RSA签名,服务提供方的公私钥只有一份,而不同的外部三方系统应持有不同的公私钥。
另外,对于用户敏感数据,服务提供方在合法合规的前提下,应做加密存储,而不是直接明文存储。
敏感数据脱敏
为保护用户隐私,用户的敏感信息经常要做脱敏处理。尤其在支付系统或金融系统,数据安全是第一要务,数据的脱敏处理更是必选项。
数据脱敏,指的是将用户敏感数据的一部分字符用特殊字符作为掩码来表示。
【身份证号脱敏示例】110115201406180712 脱敏后:110115********0712
【银行卡号脱敏示例】9558820200019833888 脱敏后:955882*********3888
【手机号脱敏示例】18810754438 脱敏后:188******38
这样即使数据被泄露了,也只泄露了一部分,不法分子拿到这份数据也没啥用。
算法实现原理很简单,就是保留头尾字符,把中间的部分用特殊字符如星号“*”作为掩码来表示。
来源:程序园用户自行投稿发布,如果侵权,请联系站长删除
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!
开发
一份
API
接口
需要
相关帖子
记一次开发
如何开发一个高效的智能体
【一步步开发AI运动APP】十一、同时检测识别多人运动,分别进行运动计时计数
VTK开发笔记(三):熟悉VTK开发流程,编写球体,多半透明球体Demo
国产化Excel开发组件Spire.XLS教程:Python 读取 CSV 文件,从基础到进阶指南
国产化Excel开发组件Spire.XLS教程:Python 将 CSV 转换为 Excel(.XLSX)
Postman接口测试全攻略:从入门到精通,看这一篇就够了
C++ 开发环境配置
美股市场股票数据API对接文档
美股市场股票数据API对接文档
vip免费申请,1年只需15美金$
回复
使用道具
举报
提升卡
置顶卡
沉默卡
喧嚣卡
变色卡
千斤顶
照妖镜
相关推荐
业界
记一次开发
0
330
奄蜊
2025-08-29
业界
如何开发一个高效的智能体
0
749
董绣梓
2025-08-30
安全
【一步步开发AI运动APP】十一、同时检测识别多人运动,分别进行运动计时计数
0
172
炀餮氢
2025-09-01
业界
VTK开发笔记(三):熟悉VTK开发流程,编写球体,多半透明球体Demo
0
802
邰怀卉
2025-09-01
业界
国产化Excel开发组件Spire.XLS教程:Python 读取 CSV 文件,从基础到进阶指南
0
587
颜清华
2025-09-03
业界
国产化Excel开发组件Spire.XLS教程:Python 将 CSV 转换为 Excel(.XLSX)
0
975
皇甫佳文
2025-09-04
科技
Postman接口测试全攻略:从入门到精通,看这一篇就够了
0
514
杜优瑗
2025-09-05
安全
C++ 开发环境配置
0
549
觐有
2025-09-06
安全
美股市场股票数据API对接文档
0
748
劳暄美
2025-09-07
安全
美股市场股票数据API对接文档
0
166
颛孙中
2025-09-07
高级模式
B
Color
Image
Link
Quote
Code
Smilies
您需要登录后才可以回帖
登录
|
立即注册
回复
本版积分规则
回帖并转播
回帖后跳转到最后一页
浏览过的版块
代码
安全
签约作者
程序园优秀签约作者
发帖
眩疝诺
2025-6-6 14:08:21
关注
0
粉丝关注
14
主题发布
板块介绍填写区域,请于后台编辑
财富榜{圆}
敖可
9984
黎瑞芝
9990
杭环
9988
4
凶契帽
9988
5
氛疵
9988
6
猷咎
9986
7
里豳朝
9986
8
肿圬后
9986
9
蝓俟佐
9984
10
虽裘侪
9984
查看更多