软件测试笔记|接口测试|如果接口的请求参数需要加密处理,你们使用的是什么加密方式?你是如何处理加密的?

常见的加密方式有以下几种用于接口请求参数加密:

一、对称加密

1. AES(高级加密标准)

• 处理方式

• 首先确定加密密钥(key)和初始向量(IV,在某些模式下需要)。在发送请求前,使用加密库(如Python中的PyCryptodome库)将请求参数进行AES加密。例如,在Python中:
from Crypto.Cipher import AES
import base64

def pad(s):
    return s + (16 - len(s) % 16) * chr(16 - len(s) % 16)

def encrypt_aes(key, iv, data):
    data = pad(data)
    cipher = AES.new(key, AES.MODE_CBC, iv)
    encrypted = cipher.encrypt(data.encode())
    return base64.b64encode(encrypted).decode()
• 然后将加密后的参数作为请求内容发送。在接收端,使用相同的密钥和初始向量进行解密操作。

二、非对称加密

1. RSA(Rivest - Shamir - Adleman)

• 处理方式

• 通常会有公钥和私钥对。在发送端,使用公钥对请求参数进行加密。例如在Java中,可以使用Bouncy Castle库来实现:
import org.bouncycastle.jce.provider.BouncyCastleProvider;
import java.security.KeyFactory;
import java.security.PublicKey;
import java.security.Security;
import java.security.spec.X509EncodedKeySpec;
import javax.crypto.Cipher;
public class RSATest {
    public static String encrypt(String data, String publicKeyStr) throws Exception {
        Security.addProvider(new BouncyCastleProvider());
        byte[] publicKeyBytes = Base64.getDecoder().decode(publicKeyStr);
        X509EncodedKeySpec keySpec = new X509EncodedKeySpec(publicKeyBytes);
        KeyFactory keyFactory = KeyFactory.getInstance("RSA", "BC");
        PublicKey publicKey = keyFactory.generatePublic(keySpec);
        Cipher cipher = Cipher.getInstance("RSA/ECB/PKCS1Padding", "BC");
        cipher.init(Cipher.ENCRYPT_MODE, publicKey);
        byte[] encrypted = cipher.doCipher(data.getBytes());
        return Base64.getEncoder().encodeToString(encrypted);
    }
}
• 在接收端则使用私钥进行解密。

在实际处理中,需要根据接口的安全需求、性能要求等因素来选择合适的加密方式,并确保加密密钥的安全存储和管理。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

阳哥整理软件测试笔记

博文不易,打赏让创作更有动力

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

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

打赏作者

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

抵扣说明:

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

余额充值