【XCTF】【GFSJ0523】【Crypto】【难度1】Caesar

"该博客详细介绍了凯撒密码的加密原理,并通过一个实际的解密挑战展示了如何通过暴力破解方法找出凯撒密码的密钥。博主分享了使用Java实现的暴力破解代码,最终解密出的密文揭示了答案:`cyberpeace{you_have_learned_caesar_encryption}
摘要由CSDN通过智能技术生成

题目来源于【攻防世界】

题目

  • 名称: Banmabanma

  • 编号: GFSJ0006

  • 难度:1

  • 题目来源:poxlove3

  • 题目描述:
    你成功的解出了来了灯谜,小鱼一脸的意想不到“没想到你懂得这么多啊!” 你心里面有点小得意,“那可不是,论学习我没你成绩好轮别的我知道的可不比你少,走我们去看看下一个” 你们继续走,看到前面也是热热闹闹的,同样的大红灯笼高高挂起,旁边呢好多人叽叽喳喳说个不停。你一看 大灯笼,上面还是一对字符,你正冥思苦想呢,小鱼神秘一笑,对你说道,我知道这个的答案是什么了

  • 题目附件:
    oknqdbqmoq{kag_tmhq_xqmdzqp_omqemd_qzodkbfuaz}

题解

  • 从题目【Caesar】可以猜出,此题应该是一个 Caesar 密码 的加解密问题。

  • 凯撒密码是古典密码学中最经典的加密算法之一。其加密原理非常简单,就是对字母进行一定量的偏移(非字母原样输出),这个偏移量便是密钥。比如: abc 经过 1 的偏移量加密后得到 bcd, 经过 2 的偏移量加密后得到 cde,经过 25 的偏移量之后得到 zab 。所以,凯撒加密最多有 25 个加密结果。

  • 但是从这道题目给出的信息中,很难判断密钥(偏移量)应该是多少

  • 索性干脆输出密钥为 1 ~ 25 的所有密文,进行暴力破解。

  • 密钥为 1 ~ 25 的密文集:
    plorecrnpr{lbh_unir_yrnearq_pnrfne_rapelcgvba} qmpsfdsoqs{mci_vojs_zsofbsr_qosgof_sbqfmdhwcb} rnqtgetprt{ndj_wpkt_atpgcts_rpthpg_tcrgneixdc} soruhfuqsu{oek_xqlu_buqhdut_squiqh_udshofjyed} tpsvigvrtv{pfl_yrmv_cvrievu_trvjri_vetipgkzfe} uqtwjhwsuw{qgm_zsnw_dwsjfwv_uswksj_wfujqhlagf} vruxkixtvx{rhn_atox_extkgxw_vtxltk_xgvkrimbhg} wsvyljyuwy{sio_bupy_fyulhyx_wuymul_yhwlsjncih} xtwzmkzvxz{tjp_cvqz_gzvmizy_xvznvm_zixmtkodji} yuxanlawya{ukq_dwra_hawnjaz_ywaown_ajynulpekj} zvybombxzb{vlr_exsb_ibxokba_zxbpxo_bkzovmqflk} awzcpncyac{wms_fytc_jcyplcb_aycqyp_clapwnrgml} bxadqodzbd{xnt_gzud_kdzqmdc_bzdrzq_dmbqxoshnm} cyberpeace{you_have_learned_caesar_encryption} dzcfsqfbdf{zpv_ibwf_mfbsofe_dbftbs_fodszqujpo} eadgtrgceg{aqw_jcxg_ngctpgf_ecguct_gpetarvkqp} fbehushdfh{brx_kdyh_ohduqhg_fdhvdu_hqfubswlrq} gcfivtiegi{csy_lezi_pievrih_geiwev_irgvctxmsr} hdgjwujfhj{dtz_mfaj_qjfwsji_hfjxfw_jshwduynts} iehkxvkgik{eua_ngbk_rkgxtkj_igkygx_ktixevzout} jfilywlhjl{fvb_ohcl_slhyulk_jhlzhy_lujyfwapvu} kgjmzxmikm{gwc_pidm_tmizvml_kimaiz_mvkzgxbqwv} lhknaynjln{hxd_qjen_unjawnm_ljnbja_nwlahycrxw} milobzokmo{iye_rkfo_vokbxon_mkockb_oxmbizdsyx} njmpcaplnp{jzf_slgp_wplcypo_nlpdlc_pyncjaetzy} oknqdbqmoq{kag_tmhq_xqmdzqp_omqemd_qzodkbfuaz}

  • 暴力尝试,得到 flag 为:cyberpeace{you_have_learned_caesar_encryption}

  • 在这里插入图片描述

附:生成密文的代码

class Solution {

    public static void main(String[] args) {
        String input = "oknqdbqmoq{kag_tmhq_xqmdzqp_omqemd_qzodkbfuaz}";
        char[] chars = input.toCharArray();
        for (int i = 1; i <= 26; i++) {	// 等于 0 或者 26 意味着含自身
            StringBuilder builder = new StringBuilder();
            for (char aChar : chars) {
                if (aChar > 'z' || aChar < 'a') {
                    builder.append(aChar);
                    continue;
                }
                builder.append(caesar(aChar, i));
            }

            System.out.println(builder);
        }
    }

    private static char caesar(char c, int offset) {
        return (char) ((c + offset - 97 ) % 26 + 97);
    }
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

HolaSecurity

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

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

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

打赏作者

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

抵扣说明:

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

余额充值