Pengeburan kod ialah teknik biasa semasa membangunkan projek PHP Tujuan utamanya adalah untuk membuat kod sukar untuk dipecahkan dan melindungi harta intelek kod.
Pengeburan kod ialah teknik yang memproses kod untuk menyukarkan pemahaman manusia. Pemprosesan ini boleh termasuk menambah kod berlebihan, menamakan semula pembolehubah dan nama fungsi, mengalih keluar ulasan dan ruang, dsb. Walaupun pengeliruan kod tidak benar-benar meningkatkan keselamatan kod, ia menyukarkan penyerang untuk melihat logik kod dan merekayasa balik rancangan serangan.
Dalam pembangunan PHP, pengeliruan kod boleh menggunakan alatan pihak ketiga seperti Zend Guard dan Ioncube. Walau bagaimanapun, penggunaan alat ini biasanya memerlukan pembayaran dan mungkin tidak boleh digunakan untuk semua projek PHP. Oleh itu, artikel ini akan memperkenalkan cara menggunakan fungsi asli PHP untuk mencapai pengeliruan kod.
Dalam PHP, pembolehubah dan nama fungsi diselesaikan pada masa jalan. Oleh itu, skrip boleh ditulis untuk menamakan semula semua pembolehubah dan nama fungsi secara automatik untuk menjadikannya lebih sukar untuk difahami. Ini boleh dicapai melalui mekanisme refleksi PHP. Refleksi ialah keupayaan untuk memeriksa kelas, kaedah dan sifat pada masa jalan. Berikut ialah contoh mudah:
<?php function myFunction($parameter1, $parameter2) { return $parameter1 + $parameter2; } $reflectionFunc = new ReflectionFunction('myFunction'); $reflectionParams = $reflectionFunc->getParameters(); foreach ($reflectionParams as $param) { $newName = generateRandomString(); renameParameter($reflectionFunc, $param->getName(), $newName); } renameFunction($reflectionFunc, 'myFunction', generateRandomString()); function renameParameter($reflectionFunc, $currentName, $newName) { $definition = $reflectionFunc->getFileName() . ':' . $reflectionFunc->getStartLine(); $contents = file_get_contents($definition); $contents = str_replace('$' . $currentName, '$' . $newName, $contents); file_put_contents($definition, $contents); } function renameFunction($reflectionFunc, $currentName, $newName) { $definition = $reflectionFunc->getFileName() . ':' . $reflectionFunc->getStartLine(); $contents = file_get_contents($definition); $contents = str_replace('function ' . $currentName, 'function ' . $newName, $contents); file_put_contents($definition, $contents); } function generateRandomString($length = 10) { $characters = '0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ'; $charactersLength = strlen($characters); $randomString = ''; for ($i = 0; $i < $length; $i++) { $randomString .= $characters[rand(0, $charactersLength - 1)]; } return $randomString; } ?>
Untuk menyukarkan kod untuk difahami, anda boleh menambah beberapa blok kod berlebihan. Blok kod ini selalunya tidak berkaitan dengan fungsi utama kod, tetapi boleh berguna dalam mengehadkan pemahaman penyerang tentang kod tersebut. Berikut ialah contoh mudah:
<?php $randomInt1 = rand(1, 10); $randomInt2 = rand(10, 100); $randomInt3 = rand(100, 1000); if ($randomInt1 > 3) { if ($randomInt2 > 50) { $tempString = "abcdefghijklmnopqrstuvwxyz1234567890"; for ($i = 0; $i < 5; $i++) { $randNum = rand(0, strlen($tempString) - 1); } } else { $tempString = "ABCDEFGHIJKLMNOPQRSTUVWXYZ1234567890"; for ($i = 0; $i < 10; $i++) { $randNum = rand(0, strlen($tempString) - 1); } } } else { if ($randomInt3 > 500) { $tempString = "$&/\+%()?!""; for ($i = 0; $i < 5; $i++) { $randNum = rand(0, strlen($tempString) - 1); } } else { $tempString = " "; for ($i = 0; $i < 10; $i++) { $randNum = rand(0, strlen($tempString) - 1); } } } ?>
Akhir sekali, semua ulasan dan ruang boleh dialih keluar sebelum mengelirukan kod. Ini boleh dicapai dengan menggunakan parser PHP. Berikut ialah contoh mudah:
<?php // Define the input to the script $input = "<?php /** * Display user comments */ function displayComments($postId) { // Connect to the database $connection = new mysqli($host, $username, $password, $dbName); // Get the comments for the post $query = "SELECT * FROM comments WHERE post_id = {$postId}"; $results = $connection->query($query); // Display the comments while ($row = $results->fetch_assoc()) { echo "<p>{$row['comment']}</p>"; } } ?>"; // Use the PHP syntax parser to remove comments and whitespace $tokens = token_get_all($input); $output = ""; foreach ($tokens as $token) { if (is_array($token)) { if ($token[0] == T_COMMENT || $token[0] == T_DOC_COMMENT) { continue; } else { $output .= $token[1]; } } else { $output .= $token; } } echo $output; ?>
Ringkasnya, proses melaksanakan pengeliruan kod dalam pembangunan PHP boleh dibahagikan kepada tiga langkah: menamakan semula pembolehubah dan nama fungsi, menambah kod berlebihan, mengalih keluar komen dan Ruang. Dengan langkah-langkah ini, kami boleh melindungi kod PHP kami dengan berkesan, menjadikannya sukar untuk memecahkan dan membuat kejuruteraan terbalik.
Atas ialah kandungan terperinci Cara menggunakan PHP untuk melaksanakan fungsi pengeliruan kod. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!