成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

SpringBoot:接口加密解密設計

開發 架構
在Spring Boot中實現接口數據的加密和解密,可以使用對稱加密算法,例如AES算法,將請求參數和響應結果進行加密和解密。

在Spring Boot中實現接口數據的加密和解密,可以使用對稱加密算法,例如AES算法,將請求參數和響應結果進行加密和解密。以下是一種示例實現方案:

添加依賴

在pom.xml文件中添加以下依賴:

<dependency>
<groupId>javax.crypto</groupId>
<artifactId>jce</artifactId>
<version>1.0.2</version>
</dependency>
<dependency>
<groupId>org.bouncycastle</groupId>
<artifactId>bcprov-jdk15on</artifactId>
<version>1.68</version>
</dependency>

實現加密和解密工具類

創建AesUtil工具類,實現AES加密和解密方法:

public class AesUtil {
// AES算法使用CBC模式和PKCS7Padding填充方式
private static final String AES_ALGORITHM = "AES/CBC/PKCS7Padding";
// AES算法的密鑰算法是AES
private static final String AES_KEY_ALGORITHM = "AES";
// 密鑰長度為16個字節,即128位
private static final String AES_KEY = "1234567812345678";
// 初始化向量長度也為16個字節,即128位
private static final String AES_IV = "1234567890123456";

// AES加密方法
public static String encrypt(String content) {
try {
byte[] keyBytes = AES_KEY.getBytes();
SecretKeySpec keySpec = new SecretKeySpec(keyBytes, AES_KEY_ALGORITHM);
Cipher cipher = Cipher.getInstance(AES_ALGORITHM, "BC");
IvParameterSpec ivSpec = new IvParameterSpec(AES_IV.getBytes());
cipher.init(Cipher.ENCRYPT_MODE, keySpec, ivSpec);
byte[] encrypted = cipher.doFinal(content.getBytes("UTF-8"));
return Base64.getEncoder().encodeToString(encrypted);
} catch (Exception e) {
throw new RuntimeException(e);
}
}

// AES解密方法
public static String decrypt(String content) {
try {
byte[] keyBytes = AES_KEY.getBytes();
SecretKeySpec keySpec = new SecretKeySpec(keyBytes, AES_KEY_ALGORITHM);
Cipher cipher = Cipher.getInstance(AES_ALGORITHM, "BC");
IvParameterSpec ivSpec = new IvParameterSpec(AES_IV.getBytes());
cipher.init(Cipher.DECRYPT_MODE, keySpec, ivSpec);
byte[] encrypted = Base64.getDecoder().decode(content);
byte[] decrypted = cipher.doFinal(encrypted);
return new String(decrypted, "UTF-8");
} catch (Exception e) {
throw new RuntimeException(e);
}
}
}

實現請求參數和響應結果加密解密攔截器

創建AesEncryptInterceptor攔截器,用于對請求參數進行加密和對響應結果進行解密:

public class AesEncryptInterceptor extends HandlerInterceptorAdapter {
@Override
public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
// 對請求參數進行加密
String content = request.getParameter("content");
if (StringUtils.isNotBlank(content)) {
String encryptedContent =AesUtil.encrypt(content);
request.setAttribute("content", encryptedContent);
}
return super.preHandle(request, response, handler);
}

@Override
public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView) throws Exception {
// 對響應結果進行解密
Object result = request.getAttribute("result");
if (result != null && result instanceof String) {
String decryptedResult = AesUtil.decrypt((String) result);
request.setAttribute("result", decryptedResult);
}
super.postHandle(request, response, handler, modelAndView);
}
}

配置攔截器

在WebMvcConfigurer配置類中添加AesEncryptInterceptor攔截器:

@Configuration
public class WebMvcConfig implements WebMvcConfigurer {
@Override
public void addInterceptors(InterceptorRegistry registry) {
registry.addInterceptor(new AesEncryptInterceptor());
}
}

完成以上步驟后,接口數據的加密和解密功能就已經實現了。以下是示例代碼:

@RestController
@RequestMapping("/api")
public class ApiController {
@GetMapping("/hello")
public String hello(@RequestParam("content") String content) {
return "Hello, " + content;
}
}

當發送請求時,請求參數content會被攔截器加密,請求被處理后返回的結果也會被攔截器解密,從而保證接口數據的安全性。

如果請求參數在body中,則需要在攔截器中讀取請求體并進行加密,同時在控制器方法中也需要讀取加密后的請求體并進行解密。

以下是修改后的代碼示例:

定義AesEncryptInterceptor攔截器

public class AesEncryptInterceptor extends HandlerInterceptorAdapter {
@Override
public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
// 對請求體進行加密
String requestBody = HttpHelper.getBodyString(request);
if (StringUtils.isNotBlank(requestBody)) {
String encryptedBody = AesUtil.encrypt(requestBody);
HttpHelper.setBodyString(request, encryptedBody);
}
return super.preHandle(request, response, handler);
}

@Override
public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView) throws Exception {
// 對響應結果進行解密
Object result = request.getAttribute("result");
if (result != null && result instanceof String) {
String decryptedResult = AesUtil.decrypt((String) result);
request.setAttribute("result", decryptedResult);
}
super.postHandle(request, response, handler, modelAndView);
}
}

定義HttpHelper類

public class HttpHelper {
public static String getBodyString(final ServletRequest request) throws IOException {
InputStream inputStream = null;
StringBuilder sb = new StringBuilder();
try {
inputStream = request.getInputStream();
BufferedReader reader = new BufferedReader(new InputStreamReader(inputStream, StandardCharsets.UTF_8));
String line;
while ((line = reader.readLine()) != null) {
sb.append(line);
}
} catch (IOException e) {
e.printStackTrace();
} finally {
if (inputStream != null) {
inputStream.close();
}
}
return sb.toString();
}

public static void setBodyString(final ServletRequest request, String body) {
try {
ServletInputStream inputStream = request.getInputStream();
BufferedReader reader = new BufferedReader(new InputStreamReader(inputStream, StandardCharsets.UTF_8));
StringBuilder sb = new StringBuilder();
String line;
while ((line = reader.readLine()) != null) {
sb.append(line);
}
String oldBody = sb.toString();
ByteArrayInputStream byteArrayInputStream = new ByteArrayInputStream(body.getBytes(StandardCharsets.UTF_8));
Field field = inputStream.getClass().getDeclaredField("in");
field.setAccessible(true);
field.set(inputStream, byteArrayInputStream);
request.setAttribute("oldBody", oldBody);
} catch (Exception e) {
e.printStackTrace();
}
}
}

在控制器中解密請求體

@RestController
@RequestMapping("/api")
public class ApiController {
@PostMapping("/hello")
public String hello(@RequestBody String requestBody) {
// 解密請求體
String decryptedRequestBody = AesUtil.decrypt(requestBody);
// 處理請求
// ...
// 返回響應結果
String responseBody = "Hello, " + decryptedRequestBody;
// 加密響應結果
return AesUtil.encrypt(responseBody);
}
}

配置攔截器

在WebMvcConfigurer配置類中添加AesEncryptInterceptor攔截器:

@Configuration
public class WebMvcConfig implements WebMvcConfigurer {
@Override
public void addInterceptors(InterceptorRegistry registry) {
registry.addInterceptor(new AesEncryptInterceptor());
}
}

完成以上步驟后,接口數據的加密和解密功能。

責任編輯:姜華 來源: 今日頭條
相關推薦

2024-07-09 10:13:15

2025-03-10 07:49:13

2021-01-07 14:17:31

Springboot數據安全加密

2022-06-04 12:25:10

解密加密過濾器

2021-03-09 13:18:53

加密解密參數

2015-03-26 14:19:53

GPG加密解密

2020-09-24 10:50:53

加密解密語言hmac

2022-12-14 09:06:58

接口Spring解密

2023-10-13 08:20:02

Spring線程池id

2010-09-07 14:10:26

PPPoE接口

2011-08-01 14:14:36

加密技術

2025-03-26 08:43:17

2021-05-08 05:56:15

加密OpenSSL密鑰

2018-07-30 11:56:17

解密加密開發

2021-12-28 13:54:52

加密密鑰Java

2009-12-09 17:56:27

PHP加密解密

2015-03-26 11:25:10

對稱加密加密壓縮加密解密解壓

2010-03-18 14:02:59

Java Runnab

2021-04-15 09:02:33

Python加密解密

2013-03-08 10:00:01

點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 精品成人在线视频 | www日韩高清 | 成人在线视频观看 | 精品小视频 | 精品一区二区三区免费毛片 | 欧美 日韩 国产 在线 | 精品国产青草久久久久96 | 亚洲一区二区三区在线视频 | 欧美日韩在线国产 | 91色啪| 日韩国产欧美一区 | 亚洲一视频 | 一区二区在线 | 久久精品亚洲欧美日韩精品中文字幕 | 求毛片| 久久久精品影院 | 国产欧美精品一区二区三区 | 四虎永久免费黄色影片 | 日韩在线小视频 | 久久一区二区三区四区五区 | 亚洲一区在线日韩在线深爱 | 国产91丝袜在线播放 | 中文字幕中文字幕 | 亚洲性视频 | 日韩精品视频在线播放 | 中文字幕在线观看精品 | 精品久久久久久亚洲综合网 | 久久久99精品免费观看 | 欧美精品一区三区 | 成人一区二区三区视频 | 欧美精品一区在线发布 | 日韩一区二区三区在线观看视频 | 国产一区二区三区 | 精品久久香蕉国产线看观看亚洲 | 五月天婷婷久久 | 欧美日韩1区 | h免费观看 | 一级毛片成人免费看a | 91成人在线视频 | 九九热在线观看视频 | 亚洲激情一级片 |