接口簽名怎么用Java實(shí)現(xiàn)
java實(shí)現(xiàn)接口簽名
為了保證數(shù)據(jù)傳輸?shù)陌踩?,跟其他系統(tǒng)進(jìn)行數(shù)據(jù)交互時(shí),雙方應(yīng)該約定好密鑰,把數(shù)據(jù)進(jìn)行加密,接口簽名,這樣雙方調(diào)用接口時(shí),驗(yàn)證接口簽名一致時(shí)就表明數(shù)據(jù)傳輸過(guò)程中沒(méi)有被修改。
后端數(shù)據(jù)簽名主要代碼:
控制器:
@Controller
public class SignController {
@Autowired
private ISignService signService;
/**
* 驗(yàn)證接口簽名
* @param dto
* @return
*/
@RequestMapping("/testSign")
@ResponseBody
public String sign(@RequestBody SignDTO dto) throws Exception{
return signService.testSign(dto);
}
}
實(shí)現(xiàn)類(lèi):
@Service
public class SignServiceImpl implements ISignService {
/**
* 獲取發(fā)起數(shù)據(jù)請(qǐng)求的簽名數(shù)據(jù),可以轉(zhuǎn)為json發(fā)起請(qǐng)求,服務(wù)端再根據(jù)接收到的數(shù)據(jù)進(jìn)行簽名驗(yàn)證,一致則證明數(shù)據(jù)傳輸過(guò)程中沒(méi)有被更改。
* @return
* @throws Exception
*/
public SignDTO getSignData() throws Exception{
User user = new User();
user.setName("測(cè)試");
user.setSex("男");
String data = JSONUtil.toJsonStr(user);
//密鑰
String accessKey = "accessKey";
String secretKey = "secretKey";
String version = "1.0";
int encrypt = 1;
long time = System.currentTimeMillis();
String nonce = RandomUtil.randomString(4);
//本地加簽
SignReqParam signReqParam = new SignReqParam(
accessKey, time, nonce, encrypt, version,
secretKey, data);
//數(shù)據(jù)加密
data = EncryptUtils.aesEncrypt(data, EncryptUtils.KEY);
System.out.println("加密后數(shù)據(jù):" + data);
SignDTO dto = new SignDTO();
dto.setAccessKey(accessKey);
dto.setVersion(version);
dto.setEncrypt(encrypt);
dto.setNonce(nonce);
dto.setTimestamp(time);
dto.setSign(signReqParam.getSign());
dto.setData(data);
return dto;
}
/**
* 返回json字符串,用于postman進(jìn)行測(cè)試數(shù)據(jù)
* @return
* @throws Exception
*/
public String getSignDataJson() throws Exception{
SignDTO dto = getSignData();
return JSONUtil.toJsonStr(dto);
}
/**
* 根據(jù)接收到的數(shù)據(jù),進(jìn)行驗(yàn)證接口簽名,正確再進(jìn)行數(shù)據(jù)處理
* @param dto
* @return
*/
@Override
public String testSign(SignDTO dto) throws Exception{
String result = "簽名不合法";
//密鑰
String accessKey = "accessKey";
String secretKey = "secretKey";
String version = "1.0";
int encrypt = 1;
if(ObjectUtils.isEmpty(dto.getVersion()) || !dto.getVersion().equals(version) || ObjectUtils.isEmpty(dto.getData()) || ObjectUtils.isEmpty(dto.getAccessKey()) || !dto.getAccessKey().equals(accessKey)){
return result;
}
// 解密為字符串
String data = EncryptUtils.aesDecrypt(dto.getData(), EncryptUtils.KEY);
System.out.println("解密后數(shù)據(jù):" + data);
//本地加簽
SignReqParam signReqParam = new SignReqParam(
accessKey, dto.getTimestamp(), dto.getNonce(), encrypt, version,
secretKey, data);
//簽名對(duì)比
if(dto.getSign().equals(signReqParam.getSign())){
User user = JSONUtil.toBean(data, User.class);
System.out.println("接口簽名合法,可以處理請(qǐng)求中的用戶(hù)信息,可以進(jìn)行一系列數(shù)據(jù)庫(kù)操作:" + user.toString());
result = "接口簽名合法";
}
return result;
}
public static void main(String[] args) throws Exception {
SignServiceImpl obj = new SignServiceImpl();
SignDTO dto = obj.getSignData();
String result = obj.testSign(dto);
System.out.println("接口簽名結(jié)果:" + result);
}
實(shí)體類(lèi):
@Data
public class SignDTO {
/*密鑰*/
private String accessKey;
/*密鑰*/
private String secretKey;
/*版本*/
private String version;
/*加密*/
private int encrypt;
/*驗(yàn)簽參數(shù)*/
private String nonce;
/*簽名*/
private String sign;
/*數(shù)據(jù)*/
private String data;
/*時(shí)間戳*/
private long timestamp;
}
@Data
public class User implements Serializable {
private String name;
private String sex;
}
main方法測(cè)試結(jié)果:
Connected to the target VM, address: '127.0.0.1:52259', transport: 'socket'
加密后數(shù)據(jù):IkoCXfjUX0dawZkLQlqkcex3TJzzQM9VsLg1UuCSvz4=
獲取接口請(qǐng)求數(shù)據(jù)json:{"data":"IkoCXfjUX0dawZkLQlqkcex3TJzzQM9VsLg1UuCSvz4=","accessKey":"accessKey","encrypt":1,"sign":"49EA679C9ED2C49E7FDB7221ECD5784F","version":"1.0","nonce":"oe9w","timestamp":1622972771180}
加密后數(shù)據(jù):IkoCXfjUX0dawZkLQlqkcex3TJzzQM9VsLg1UuCSvz4=
解密后數(shù)據(jù):{"sex":"男","name":"測(cè)試"}
接口簽名合法,可以處理請(qǐng)求中的用戶(hù)信息,可以進(jìn)行一系列數(shù)據(jù)庫(kù)操作:User(name=測(cè)試, sex=男)
接口簽名結(jié)果:接口簽名合法
Disconnected from the target VM, address: '127.0.0.1:52259', transport: 'socket'
postman測(cè)試結(jié)果:

到此這篇關(guān)于接口簽名怎么用Java實(shí)現(xiàn)的文章就介紹到這了,更多相關(guān)java實(shí)現(xiàn)接口簽名內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Java獲取調(diào)用當(dāng)前方法的類(lèi)名或方法名(棧堆信息)的四種方式舉例
在Java編程中我們經(jīng)常需要在運(yùn)行時(shí)獲取當(dāng)前執(zhí)行的方法名稱(chēng),這在日志記錄、性能監(jiān)控、調(diào)試等方面非常有用,這篇文章主要給大家介紹了關(guān)于Java獲取調(diào)用當(dāng)前方法的類(lèi)名或方法名(棧堆信息)的四種方式,需要的朋友可以參考下2024-09-09
JAVA使用JDBC技術(shù)操作SqlServer數(shù)據(jù)庫(kù)實(shí)例代碼
本篇文章主要介紹了JAVA使用JDBC技術(shù)操作SqlServer數(shù)據(jù)庫(kù)實(shí)例代碼,具有一定的參考價(jià)值,有興趣的可以了解一下。2017-01-01
Spring Boot引入swagger-ui 后swagger-ui.html無(wú)法訪問(wèn)404的問(wèn)題
這篇文章主要介紹了Spring Boot引入swagger-ui 后swagger-ui.html無(wú)法訪問(wèn)404的問(wèn)題及解決方法,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-09-09
SpringBoot2 task scheduler 定時(shí)任務(wù)調(diào)度器四種方式
這篇文章主要介紹了SpringBoot2 task scheduler 定時(shí)任務(wù)調(diào)度器四種方式,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-03-03
Win10 Java jdk14.0.2安裝及環(huán)境變量配置詳細(xì)教程
這篇文章主要介紹了Win10 Java jdk14.0.2安裝及環(huán)境變量配置,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-08-08
java實(shí)現(xiàn)簡(jiǎn)易版圖形界面計(jì)算器
這篇文章主要為大家詳細(xì)介紹了java實(shí)現(xiàn)簡(jiǎn)易版圖形界面計(jì)算器,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-05-05
學(xué)會(huì)在Java中使用Optional功能
這篇文章主要介紹了學(xué)會(huì)在Java中使用Optional功能,在本文中,我們將了解如何、何時(shí)以及在哪里最好地應(yīng)用Optional,具體相關(guān)內(nèi)容需要的朋友可以參考下面文章內(nèi)容2022-09-09

