响应数据加密解决方案

在这里插入图片描述

需求分析

响应数据加密是一种很重要的安全措施,可以保护数据在传输过程中不被未经授权的用户拦截、窃取或篡改。以下是响应数据加密需求分析:

  1. 响应数据必须进行加密:
    所有响应数据必须进行加密,以保证数据在传输过程中的安全性。服务器可以采用HTTPS协议对响应数据进行加密传输,或者预设加密算法等方案进行加密。
  2. 使用强加密算法:
    对响应数据进行加密时,必须使用强加密算法,如AES和RSA等。强加密算法具有高强度的加密保护,使得未授权用户无法窃取这些数据。
  3. 保障数据传输完整性:
    在传输数据之前,需要对数据进行数字签名或加上一个散列值,以确保数据传输的完整性。数字签名和散列值采用了MD5、SHA-1等强加密算法进行计算,以保证传输过程中数据不受篡改。
  4. 防止重放攻击:
    在响应数据中包含时间戳和随机数等信息,以防止恶意用户通过重播响应数据来攻击系统。在服务器端对时间戳和随机数进行验证,确定其与请求数据的相关性后,再响应给客户端。
  5. 提供API或开放平台接口时,必须采用严格的权限控制机制,保障数据的安全性。
    以上是响应数据加密需求分析的示例,通过良好的加密方案、强加密算法以及高效可靠的验证机制,可以保护响应数据在传输过程中的安全性。

解决方案

为了解决响应数据安全的问题我们引入了AES加密,通过前后端协议的秘钥进行加密和解码,这样数据返回的始终是加密串,我们采用了AOP进行全局加密响应数据。

实现步骤

AES加密解密工具类

具体操作步骤如下:

  1. 声明常量key作为加密和解密的key值
  2. 加密方法
    1. 入参为json字符串
    2. 返回参为加密字符串
  3. 解密方法
    1. 入参为加密字符串
    2. 返回参为解密后的json字符串
public class AESCrypt {
    public static final String KEY = "b45585ec768e4b60";
    /**
     * 加密
     *
     * @param data json数据
     * @return 加密串
     */
    public static String encrypt(String data) {
        AES aes = new AES(Mode.ECB, Padding.ISO10126Padding, KEY.getBytes(StandardCharsets.UTF_8));
        return aes.encryptBase64(data);
    }

    /**
     * 解密
     *
     * @param data 加密串
     * @return json数据
     */
    public static String decrypt(String data) {
        AES aes = new AES(Mode.ECB, Padding.ISO10126Padding, KEY.getBytes(StandardCharsets.UTF_8));
        return aes.decryptStr(data);
    }
}

AOP处理响应数据

这里我们用到了环绕切面around方法
具体操作步骤如下:

  1. 获取相应数据对象
  2. 校验是否要加密(这里我们只对data数据不为null的进行加密,例如、查询)
    1. 如果返回的数据类型为String,则直接将对象中的data转为String,再进行加密
    2. 如果返回的数据是其他类型,则先试用Gson将对象中的data转为json字符串,再进行加密
    3. 其他返回类型这里没有判断可能会出现错误(后期处理)。
@Component
@Aspect
@Order(2)
public class AesAspect {

    @Autowired
    private HttpServletRequest request;

    @Value("${encrypt}")
    private boolean encrypt;

    /**
     * 过滤切入点
     */
    @Pointcut("execution(* com.llfy.saapp.page.*.controller.*Controller.*(..))")
    public void pointCut1() {
    }

    /**
     * 切入点
     */
    @Pointcut("pointCut1()")
    public void pointCut() {
    }


    /**
     * 环绕切面
     *
     * @param proceedingJoinPoint 进行中的连接点
     * @return {@link Object}
     */
    @SneakyThrows
    @Around("pointCut()")
    public Object around(ProceedingJoinPoint proceedingJoinPoint) {
        RespJson result = (RespJson) proceedingJoinPoint.proceed();
        if (result != null && result.isOk() && encrypt && result.getData() != null){
            if (result.getData() instanceof String){
                result.setData(AESCrypt.encrypt(result.getData().toString()));
            }else {
                result.setData(AESCrypt.encrypt(new Gson().toJson(result.getData())));
            }
        }
        return result;
    }
}

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

刘凌枫羽

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值