Java—通过sign签名认证实现安全的开放接口API
关注微信公众号:CodingTechWork,一起学习进步。
文章目录
引言
在开发Java API
时,有可能需要一些安全认证来保证API
的安全性。下面,我们通过timestamp
以及sign签名认证
来实现基本的安全的开发接口API
。
API接口
curl {ip}:{port}/demo/test/app -X POST -H "Content-Type:application/json" -d '
{
"appId":"app01",
"key01": "value01",
"key02": "value02,
"key03": "value03",
"sign": "77f4d9119d43c41491ab8a7c0530a618d6e0823560eb6dd028f62ae56b1ab7bb",
"timestamp":165820977
}'
timestamp保证唯一性
通过timestamp校验,保证约定时间内请求的唯一性
shell生成timestamp
- shell中生成秒级timestamp
echo $(date '+%s')
- shell中生成毫秒级timestamp
# 通过纳秒除以1000000的方式实现
echo $[$(date '+%s%N')/1000000]
java生成timestamp模板
// 得到秒级
long currentTimeStamp = System.currentTimeMillis() / 1000;
sign签名认证
实现方式
- app服务端配置对应appSecret, 例如app123456
- 所有请求参数按照字母排序, 配装字符串, 采用
key=value
并用&
链接 - 添加签名
appSecret
, 字符末尾加上appSecret=app123456
- 采用
SHA-256
生产签名 - 例:
appId=app01¶ms=key01=value01;key02=value02;key03=value03&appSecret=app123456
shell生成sha-256值
echo -n "appId=app01¶ms=key01=value01;key02=value02;key03=value03&appSecret=app123456" | sha256sum | awk '{print $1}'
结果
77f4d9119d43c41491ab8a7c0530a618d6e0823560eb6dd028f62ae56b1ab7bb
java生成sha-256模板
package com.demo.test
import java.io.UnsupportedEncodingException;
import java.security.MessageDigest;
import java.security.NoSuchAlgorithmException;
import java.util.Base64;
import org.apache.commons.lang.StringUtils;
import lombok.extern.slf4j.Slf4j;
@Slf4j
public class Encrypt {
/**
* 返回 SHA-256 串
*
* @param strText
* @return
*/
public static String SHA256(final String strText) {
return SHA(strText, "SHA-256");
}
/**
* 返回 SHA-512 串
*
* @param strText
* @return
*/
public static String SHA512(final String strText) {
return SHA(strText, "SHA-512");
}
public static String MD5(final String strText) {
return SHA(strText, "MD5");
}
/**
* SHA 加密
*
* @param strText
* @return
*/
private static String SHA(final String strText, final String type) {
String ret = null;
if (strText != null && strText.length() > 0) {
try {
MessageDigest messageDigest = MessageDigest.getInstance(type);
messageDigest.update(strText.getBytes());
byte[] buffer = messageDigest.digest();
StringBuffer sb = new StringBuffer();
for (int i = 0; i < buffer.length; i++) {
String hex = Integer.toHexString(0xff & buffer[i]);
if (hex.length() == 1) {
sb.append('0');
}
sb.append(hex);
}
ret = sb.toString();
} catch (NoSuchAlgorithmException e) {
log.error("{} encrypt failed.{}", type, e);
}
}
return ret;
}
/**
* 手机号脱敏处理
*
* @param phone
* @return
*/
public static String desensitizedPhone(String phone) {
if (StringUtils.isNotEmpty(phone)) {
phone = phone.replaceAll("(\\w{3})\\w*(\\w{4})", "$1****$2");
}
return phone;
}
/**
* base64加密
*
* @param content
* @return
*/
public static String base64Encoder(String content) {
try {
String base64encodedString = Base64.getEncoder().encodeToString(content.getBytes("utf-8"));
return base64encodedString;
} catch (UnsupportedEncodingException e) {
log.error("base64Encoder failed", e);
}
return null;
}
/**
* base64解密
*
* @param content
* @return
*/
public static String base64Decoder(String content) {
try {
// 解码
byte[] base64decodedBytes = Base64.getDecoder().decode(content);
return new String(base64decodedBytes, "utf-8");
} catch (UnsupportedEncodingException e) {
log.error("base64Decoder failed", e);
}
return null;
}
}
烧不死的鸟就是凤凰
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 全程不用写代码,我用AI程序员写了一个飞机大战
· DeepSeek 开源周回顾「GitHub 热点速览」
· 记一次.NET内存居高不下排查解决与启示
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET10 - 预览版1新功能体验(一)