基于Base64的对称加密

本文探讨了Base64加密的局限性,由于其辨识度高,容易被开发人员识别并解密。为增强安全性,提出了一种方法:保留部分原始密文,将加密后密文的偶数位进行前后调换。解密过程需逆向操作,增加了破解的难度。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

base64加密辨识度太高,很多开发人员都能通过密文看出这种加密方式,然后解密得到明文。我们可以通过对密文进一步加工,使别人无法直接使用base64解密得到明文。

下面的代码是c#语法,基本思路是将加密之后的密文的后面的一小部分保留,然后我们将前面偶数位的密文,分成两部分前后调换,解密的思路与之是一样的。

class Tool
{
    public string Encrypt(string plaintext)
    {
        string raw = Base64_encode(plaintext);
        int len = 0;
        if (raw.Length % 2 == 0)
        {
            len = raw.Length - 2;
        }
        else
        {
            len = raw.Length - 1;
        }
        string first = raw.Substring(0, len/2);
        string second = raw.Substring(len/2,len/2);
        string end = raw.Substring(len);
        string ciphertext = second + first + end;
        return ciphertext;
    }
    public string Decrypt(string ciphertext)
    {
        int len = 0;
        if (ciphertext.Length % 2 == 0)
        {
            len = ciphertext.Length - 2;
        }
        else
        {
            len = ciphertext.Length - 1;
        }
        string first = ciphertext.Substring(0, len/2);
        string second = ciphertext.Substring(len/2, len/2);
        string end = ciphertext.Substring(len);
        string raw = second + first + end;
        string plaintext = Base64_decode(raw);
        return plaintext;
    }
    public string Base64_encode(string plaintext)
    {
        byte[] bytes = Encoding.Default.GetBytes(plaintext);
        return Convert.ToBase64String(bytes);
    }
    public string Base64_decode(string ciphertext)
    {
        byte[] bytes = Convert.FromBase64String(ciphertext);
        return Encoding.Default.GetString(bytes);
    }
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值