接口簽名怎么用Java實(shí)現(xiàn)
java實(shí)現(xiàn)接口簽名
為了保證數(shù)據(jù)傳輸?shù)陌踩裕渌到y(tǒng)進(jìn)行數(shù)據(jù)交互時(shí),雙方應(yīng)該約定好密鑰,把數(shù)據(jù)進(jìn)行加密,接口簽名,這樣雙方調(diào)用接口時(shí),驗(yàn)證接口簽名一致時(shí)就表明數(shù)據(jù)傳輸過程中沒有被修改。
后端數(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)類:
@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ù)傳輸過程中沒有被更改。
* @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)求中的用戶信息,可以進(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í)體類:
@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)求中的用戶信息,可以進(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)文章
SpringBoot實(shí)現(xiàn)權(quán)限驗(yàn)證的示例步驟
權(quán)限驗(yàn)證是一種用于控制對(duì)系統(tǒng)資源和操作的訪問的機(jī)制。它允許開發(fā)人員定義誰可以執(zhí)行特定操作或訪問特定資源,并確保只有經(jīng)過授權(quán)的用戶才能執(zhí)行這些操作,這篇文章主要介紹了SpringBoot實(shí)現(xiàn)權(quán)限驗(yàn)證,需要的朋友可以參考下2023-08-08
Java實(shí)現(xiàn)簡(jiǎn)單的socket通信教程
這篇文章主要介紹了Java實(shí)現(xiàn)簡(jiǎn)單的socket通信教程,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2020-12-12
Java實(shí)現(xiàn)時(shí)間動(dòng)態(tài)顯示方法匯總
這篇文章主要介紹了Java實(shí)現(xiàn)時(shí)間動(dòng)態(tài)顯示方法匯總,很實(shí)用的功能,需要的朋友可以參考下2014-08-08
如何基于mybatis框架查詢數(shù)據(jù)庫(kù)表數(shù)據(jù)并打印
這篇文章主要介紹了如何基于mybatis框架查詢數(shù)據(jù)庫(kù)表數(shù)據(jù)并打印,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-11-11

