凯撒密码 | 加密解密

该博客介绍了如何利用凯撒密码和Base64编码进行字符串的加密与解密。通过KaiSaCipher类展示了具体实现过程,包括加密方法encryption()、解密方法decrypt()以及移位算法xun()。博客使用了Hutool工具库的RandomUtil和Base64Util类来辅助加密解密操作。

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

/**
 * @className: KaiSaCipher
 * @description: 凯撒密码加密解密
 **/
@Component
public class KaiSaCipher {
    public static void main(String[] args) {
        String str = "0hZEAMMTkyLjE2Ny4xMy41";

        KaiSaCipher kaiSaCipher = new KaiSaCipher();
        String encryption = kaiSaCipher.encryption(str);
        String decrypt = kaiSaCipher.decrypt(encryption);

        System.out.println("明文: " + str);
        System.out.println("密文: " + encryption);
        System.out.println("解密后: " + decrypt);
    }

    /**
     * 加密字符串
     */
    public String encryption(String str) {
        //生成区间随机数,偏移量
        int k = RandomUtil.randomInt(0, 9);
        String string = "";
        //base64加密
        string = Base64Util.encode(xun(str, string, k));
        return k + string;
    }

    /**
     * 解密字符串
     */
    public String decrypt(String str) {
        int n = Integer.parseInt(str.substring(0, 1));
        str = Base64Util.decode(str.substring(1));
        int k = -n;
        String string = "";
        return xun(str, string, k);
    }

    /**
     * 移位算法
     */
    private String xun(String str, String string, int k) {
        StringBuilder stringBuilder = new StringBuilder(string);
        for (int i = 0; i < str.length(); i++) {
            char c = str.charAt(i);
            if (c >= 'a' && c <= 'z')//如果字符串中的某个字符是小写字母
            {
                c += k % 26;//移动key%26位
                if (c < 'a')
                    c += 26;//向左超界
                if (c > 'z')
                    c -= 26;//向右超界
            } else if (c >= 'A' && c <= 'Z')//如果字符串中的某个字符是大写字母
            {
                c += k % 26;//移动key%26位
                if (c < 'A')
                    c += 26;//向左超界
                if (c > 'Z')
                    c -= 26;//向右超界
            } else if (c >= '0' && c <= '9')//字符串中数字
            {
                c += k % 10;//移动key%26位
                if (c < '0')
                    c += 10;//向左超界
                if (c > '9')
                    c -= 10;//向右超界
            }
            stringBuilder.append(c);//将解密后的字符连成字符串
        }
        string = stringBuilder.toString();
        return string;
    }
}
RandomUtil,Base64Util为Hutool工具类, Hutool是一个小而全的Java工具类库Hutool工具类
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值