【加解密与C】Rot系列(四)Rot47

Rot47 简介

Rot47 是一种基于 ASCII 码的字符替换算法,属于 Rot13 的扩展版本。它将可打印的 ASCII 字符(从 33 '!' 到 126 '~')通过移位 47 位进行替换。与 Rot13 仅处理字母不同,Rot47 支持数字、符号和字母的转换。

Rot47 算法原理

  1. 字符范围:仅处理 ASCII 值在 33('!')到 126('~')之间的字符。
  2. 移位规则
    • 对字符的 ASCII 码值加 47。
    • 若结果超过 126,则取模后重新映射到 33 开始。
    • 公式表示为:

      \\text{rot47}(c) = (c - 33 + 47) \\mod 94 + 33

  3. 自反性:与 Rot13 类似,Rot47 也是自反的,即两次应用会恢复原始文本。

应用场景

  • 简单数据混淆:用于临时隐藏文本内容(如配置文件中的敏感信息)。
  • 编程挑战:常见于 CTF 比赛或编码练习。
  • 避免直接扫描:防止自动化工具直接识别明文关键字。

注意事项

  • 安全性低:Rot47 不提供加密,仅作为简单混淆手段。
  • 字符支持:不支持非 ASCII 字符(如中文、emoji)。

如需更高安全性,建议使用 AES 等标准加密算法。

cpp 复制代码
#include <stdio.h>
#include <stdlib.h>
#include <string.h>

/**
 * ROT47编码/解码函数
 * ROT47对所有可打印ASCII字符(33-126)进行47位旋转:
 *   ! → P, " → Q, # → R, ..., ~ → }
 *   旋转后仍在33-126范围内
 * 
 * 注意:ROT47是对称密码,编码和解码使用相同的算法
 * 
 * @param input 输入字符串
 * @return 转换后的新字符串(需调用者释放内存)
 */
char* rot47_transform(const char* input) {
    if (!input) return NULL;
    
    size_t len = strlen(input);
    char* output = malloc(len + 1);  // +1 for null terminator
    if (!output) return NULL;
    
    for (size_t i = 0; i < len; i++) {
        unsigned char c = input[i];
        // 仅处理33-126范围内的可打印ASCII字符
        if (c >= 33 && c <= 126) {
            // 应用ROT47转换
            output[i] = 33 + ((c - 33 + 47) % 94);
        } else {
            // 非可打印字符保持不变
            output[i] = c;
        }
    }
    output[len] = '\0';
    return output;
}
相关推荐
极客小张2 小时前
【项目思路】基于STM32+ZigBee的智能家居--浴室场景设计
c语言·python·stm32·智能家居·课程设计·项目设计·企业项目
仰泳之鹅5 小时前
【C语言】深入理解指针(5)
c语言·开发语言
无为之士6 小时前
君正交叉编译链工具mips-gcc540-glibc222-64bit-r3.3.0.smaller.bz2编译st-device-sdk-c
c语言·开发语言
古译汉书10 小时前
嵌入式铁头山羊stm32-SAR型ADC模块介绍、采样时间、转换时间-Day24
c语言·stm32·单片机·嵌入式硬件·iot
我不是板神12 小时前
秋招|MCU+RTOS技术栈——面试八股文整理3:STM32
c语言
C灿灿数模13 小时前
2025全国大学生数学建模C题保姆级思路模型(持续更新):NIPT 的时点选择与胎儿的异常判定
c语言·开发语言·数学建模
啊?啊?14 小时前
17 C 语言宏进阶必看:从宏替换避坑到宏函数用法,不定参数模拟实现一次搞定
c语言·预处理·文本替换
热心网友俣先生16 小时前
2025年数学建模国赛C题超详细解题思路
c语言·开发语言·数学建模
jiaway17 小时前
【C语言】第二课 位运算
c语言·开发语言·算法
Vae_Mars17 小时前
C语言中的关键字
c语言·开发语言