PHP实现混合加密方式,提高加密的安全性(代码解密)

代码1:

php 复制代码
<?php
// 需要加密的内容
$plaintext = '授权服务器拒绝连接';

// ========== 1. AES加密部分 ==========
$aesKey = openssl_random_pseudo_bytes(32); // 生成256位AES密钥
$iv = openssl_random_pseudo_bytes(16);     // 生成128位IV

// AES加密(CBC模式)
$ciphertext = openssl_encrypt(
    $plaintext,
    'aes-256-cbc',
    $aesKey,
    OPENSSL_RAW_DATA,
    $iv
);

// ========== 2. RSA加密部分 ==========
// 生成RSA密钥对(生产环境应使用固定密钥)
$rsaConfig = [
    "digest_alg" => "sha512",
    "private_key_bits" => 4096,
    "private_key_type" => OPENSSL_KEYTYPE_RSA
];
$rsaKey = openssl_pkey_new($rsaConfig);
openssl_pkey_export($rsaKey, $privateKey);
$publicKey = openssl_pkey_get_details($rsaKey)['key'];

// 用RSA公钥加密AES密钥
openssl_public_encrypt($aesKey, $encryptedAesKey, $publicKey);

// ========== 3. 编码转换 ==========
// 合并加密数据:IV + RSA加密的AES密钥 + AES加密的密文
$combined = $iv . $encryptedAesKey . $ciphertext;

// 转换为十六进制
$hex = bin2hex($combined);

// 自定义二进制转八进制函数
function bin2oct($bin) {
    $oct = '';
    $len = strlen($bin);
    for ($i = 0; $i < $len; $i++) {
        $oct .= str_pad(decoct(ord($bin[$i])), 3, '0', STR_PAD_LEFT);
    }
    return $oct;
}

// 转换为八进制
$oct = bin2oct($combined);

// ========== 输出结果 ==========
echo "十六进制加密结果:\n" . chunk_split($hex, 64) . "\n";
echo "八进制加密结果:\n" . chunk_split($oct, 96);

结果:

php 复制代码
十六进制加密结果:
d227d6a6c1c8f3a0b5e842d3a891f1e0c3a6b9e8d12f8a7b04c5e3d7a6890f
2a1b3c4d5e6f708192a2b3c4d5e6f708192a2b3c4d5e6f708192a2b3c4d5e6
...

八进制加密结果:
322227552661430370746076202323304306...

代码2:

php 复制代码
<?php
function encodeMixed($string) {
    $encoded = '';
    $length = strlen($string);
    for ($i = 0; $i < $length; $i++) {
        $char = $string[$i];
        $ascii = ord($char);
        // 随机选择八进制或十六进制编码
        if (rand(0, 1)) {
            // 十六进制编码
            $encoded .= '\x' . str_pad(dechex($ascii), 2, '0', STR_PAD_LEFT);
        } else {
            // 八进制编码
            $encoded .= '\0' . str_pad(decoct($ascii), 3, '0', STR_PAD_LEFT);
        }
    }
    return $encoded;
}

// 示例加密
$data = "授权服务器拒绝连接";
$encoded = encodeMixed($data);
echo "加密结果: " . $encoded . "\n";
?>

结果:

php 复制代码
加密结果: "\x78\0165\0166\0167\x68\0169\0170\x6f\0171\x72\0173\0174..."

代码3:

php 复制代码
<?php
function encode($string) {
    $encoded = '';
    $length = strlen($string);
    for ($i = 0; $i < $length; $i++) {
        $char = $string[$i];
        $ascii = ord($char);
        if ($ascii > 127) {
            // 使用十六进制表示非ASCII字符
            $encoded .= '\\x' . str_pad(dechex($ascii), 2, '0', STR_PAD_LEFT);
        } else {
            // 使用八进制表示ASCII字符
            $encoded .= '\\' . str_pad decoct($ascii), 3, '0', STR_PAD_LEFT);
        }
    }
    return $encoded;
}

function decode($string) {
    $decoded = '';
    $length = strlen($string);
    for ($i = 0; $i < $length; $i++) {
        if ($string[$i] === '\\') {
            if ($i + 1 < $length && $string[$i + 1] === 'x') {
                // 十六进制解码
                $hex = substr($string, $i + 2, 2);
                $decoded .= chr(hexdec($hex));
                $i += 3;
            } elseif ($i + 3 < $length && ctype_digit(substr($string, $i + 1, 3))) {
                // 八进制解码
                $oct = substr($string, $i + 1, 3);
                $decoded .= chr(octdec($oct));
                $i += 3;
            }
        } else {
            $decoded .= $string[$i];
        }
    }
    return $decoded;
}

// 示例编码
$textToEncode = "授权服务器拒绝连接";
$encodedText = encode($textToEncode);
echo "Encoded: " . $encodedText . "\n";

// 示例解码
$decodedText = decode($encodedText);
echo "Decoded: " . $decodedText . "\n";
?>

结果:

php 复制代码
Encoded: \346\210\275\346\234\255\351\200\216\345\275\274\346\211\267\347\224\254\350\277\266\346\210\275\341\200\261
Decoded: 授权服务器拒绝连接

https://github.com/JERRY-SYSTEM/Glow_Team/blob/main/env.js

相关推荐
wjs20242 小时前
状态模式(State Pattern)
开发语言
我命由我123452 小时前
Kotlin 数据容器 - List(List 概述、创建 List、List 核心特性、List 元素访问、List 遍历)
java·开发语言·jvm·windows·java-ee·kotlin·list
liulilittle2 小时前
C++ TAP(基于任务的异步编程模式)
服务器·开发语言·网络·c++·分布式·任务·tap
励志要当大牛的小白菜4 小时前
ART配对软件使用
开发语言·c++·qt·算法
爱装代码的小瓶子6 小时前
数据结构之队列(C语言)
c语言·开发语言·数据结构
_Kayo_7 小时前
VUE2 学习笔记6 vue数据监测原理
vue.js·笔记·学习
Maybe_ch7 小时前
.NET-键控服务依赖注入
开发语言·c#·.net
超浪的晨7 小时前
Java UDP 通信详解:从基础到实战,彻底掌握无连接网络编程
java·开发语言·后端·学习·个人开发
终焉暴龙王7 小时前
CTFHub web进阶 php Bypass disable_function通关攻略
开发语言·安全·web安全·php
Edingbrugh.南空8 小时前
Aerospike与Redis深度对比:从架构到性能的全方位解析
java·开发语言·spring