Rumah pembangunan bahagian belakang tutorial php Pengendalian ralat PHP: elakkan daripada mendedahkan maklumat sensitif

Pengendalian ralat PHP: elakkan daripada mendedahkan maklumat sensitif

Aug 11, 2023 am 08:31 AM
Ralat pengendalian maklumat sensitif awam

PHP 错误处理:避免公开敏感信息

Pengendalian Ralat PHP: Elakkan daripada mendedahkan maklumat sensitif

Pengendalian ralat adalah bahagian yang sangat penting semasa membangunkan aplikasi PHP. Pengendalian ralat yang baik boleh membantu pembangun mencari dan membetulkan ralat dengan cepat apabila masalah program berlaku, meningkatkan kestabilan dan kebolehpercayaan aplikasi. Walau bagaimanapun, semasa pengendalian ralat, kadangkala beberapa maklumat sensitif mungkin terdedah secara tidak sengaja, seperti maklumat sambungan pangkalan data, laluan fail, dsb. Untuk melindungi keselamatan aplikasi dan pengguna kami, kami perlu mengelak daripada mendedahkan maklumat sensitif ini.

Yang berikut akan memperkenalkan beberapa kaedah untuk mengelak daripada mendedahkan maklumat sensitif dalam pengendalian ralat PHP.

  1. Matikan paparan ralat

Dalam persekitaran pengeluaran, kami harus melumpuhkan paparan mesej ralat PHP. Mematikan paparan mesej ralat boleh menghalang penggodam daripada menggunakan maklumat ini untuk melakukan serangan. Kami boleh menetapkan paparan ralat kepada mematikan dalam fail kemasukan utama projek:

<?php
error_reporting(0);
ini_set('display_errors', 0);
Salin selepas log masuk

Selepas menetapkan ini, walaupun ralat berlaku, mesej ralat khusus tidak akan dipaparkan dalam penyemak imbas, tetapi log ralat akan disimpan ke log yang ditentukan dalam fail.

  1. Gunakan fungsi pengendalian ralat tersuai

Selain mematikan paparan ralat, kami juga boleh menggunakan fungsi pengendalian ralat tersuai untuk mengendalikan ralat PHP. Dengan menangkap maklumat ralat, kami boleh menulis log ralat secara selektif untuk log fail dan memberikan gesaan ralat umum kepada pengguna dan bukannya maklumat ralat khusus.

<?php
function customErrorHandler($errno, $errstr, $errfile, $errline) {
    // 将错误信息写入日志文件
    $log = date('Y-m-d H:i:s') . ' - ' . $errno . ': ' . $errstr . ' in ' . $errfile . ' on line ' . $errline . PHP_EOL;
    file_put_contents('errorlog.txt', $log, FILE_APPEND);

    // 提示用户发生了错误
    echo '抱歉,系统出现了一些问题,请稍后再试。';
}
set_error_handler('customErrorHandler');
Salin selepas log masuk

Dalam kod di atas, kami mendaftarkan fungsi pengendalian ralat tersuai customErrorHandler sebagai fungsi pengendalian ralat lalai melalui fungsi set_error_handler. Apabila ralat berlaku, sistem akan memanggil fungsi ini secara automatik untuk mengendalikan ralat. set_error_handler 函数将自定义的错误处理函数 customErrorHandler 注册为默认的错误处理函数。当出现错误时,系统会自动调用该函数来处理错误。

需要注意的是,我们在自定义的错误处理函数中,要避免直接将错误信息输出到用户的浏览器。因为在某些情况下,错误信息可能包含敏感信息。

  1. 使用异常处理

除了使用错误处理函数,PHP 还提供了异常处理的机制。与错误处理函数相比,异常处理可以提供更加清晰和灵活的错误处理方式。

<?php
try {
    // 业务逻辑代码
} catch (Exception $e) {
    // 将异常信息写入日志文件
    $log = date('Y-m-d H:i:s') . ' - ' . $e->getMessage() . ' in ' . $e->getFile() . ' on line ' . $e->getLine() . PHP_EOL;
    file_put_contents('errorlog.txt', $log, FILE_APPEND);

    // 提示用户发生了错误
    echo '抱歉,系统出现了一些问题,请稍后再试。';
}
Salin selepas log masuk

使用异常处理时,我们可以直接通过 try...catch

Perlu diingat bahawa dalam fungsi pengendalian ralat tersuai kami, kami mesti mengelak daripada mengeluarkan maklumat ralat terus ke penyemak imbas pengguna. Kerana dalam sesetengah kes, mesej ralat mungkin mengandungi maklumat sensitif.
    1. Gunakan pengendalian pengecualian

    Selain menggunakan fungsi pengendalian ralat, PHP juga menyediakan mekanisme pengendalian pengecualian. Berbanding dengan fungsi pengendalian ralat, pengendalian pengecualian boleh memberikan cara pengendalian ralat yang lebih jelas dan lebih fleksibel.

    chmod 600 errorlog.txt
    Salin selepas log masuk

    Apabila menggunakan pengendalian pengecualian, kita boleh menangkap kemungkinan pengecualian secara langsung melalui blok cuba...tangkap. Apabila pengecualian berlaku, kami boleh menulis maklumat pengecualian secara selektif pada fail log dan mengembalikan mesej ralat umum kepada pengguna.

    Beri perhatian kepada kebenaran fail log

    🎜Apabila menulis maklumat ralat pada fail log, kita perlu memastikan bahawa direktori dan kebenaran fail fail log ditetapkan dengan betul. Kami perlu melarang operasi selain daripada kebenaran membaca pada fail untuk menghalang penggodam daripada mendapatkan maklumat sensitif. 🎜🎜Dalam persekitaran Linux, kita boleh menggunakan arahan berikut untuk menetapkan kebenaran fail log: 🎜rrreee🎜Dalam persekitaran Windows, kita boleh menetapkan kebenaran fail melalui atribut fail. 🎜🎜Untuk meringkaskan, anda perlu mengelak daripada mendedahkan maklumat sensitif semasa mengendalikan ralat PHP. Kami boleh melindungi aplikasi dan pengguna kami dengan mematikan paparan ralat, menggunakan fungsi pengendalian ralat tersuai, menggunakan pengendalian pengecualian dan menetapkan kebenaran pada fail log dengan betul. Mekanisme pengendalian ralat yang munasabah adalah bahagian penting dalam memastikan operasi aplikasi yang stabil. 🎜

    Atas ialah kandungan terperinci Pengendalian ralat PHP: elakkan daripada mendedahkan maklumat sensitif. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn

Alat AI Hot

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

AI Hentai Generator

AI Hentai Generator

Menjana ai hentai secara percuma.

Artikel Panas

R.E.P.O. Kristal tenaga dijelaskan dan apa yang mereka lakukan (kristal kuning)
1 bulan yang lalu By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Tetapan grafik terbaik
1 bulan yang lalu By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Cara Memperbaiki Audio Jika anda tidak dapat mendengar sesiapa
1 bulan yang lalu By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Arahan sembang dan cara menggunakannya
1 bulan yang lalu By 尊渡假赌尊渡假赌尊渡假赌

Alat panas

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Menggunakan perisian tengah untuk meningkatkan pengendalian ralat dalam fungsi golang Menggunakan perisian tengah untuk meningkatkan pengendalian ralat dalam fungsi golang Apr 24, 2024 pm 06:57 PM

Gunakan middleware untuk meningkatkan pengendalian ralat dalam fungsi Go: Memperkenalkan konsep middleware, yang boleh memintas panggilan fungsi dan melaksanakan logik tertentu. Buat perisian tengah pengendalian ralat yang membungkus logik pengendalian ralat dalam fungsi tersuai. Gunakan middleware untuk membalut fungsi pengendali supaya logik pengendalian ralat dilakukan sebelum fungsi dipanggil. Mengembalikan kod ralat yang sesuai berdasarkan jenis ralat, улучшениеобработкиошибоквфункциях Goспомощьюпромежуточногопрограммногообеспечения.Оноспечечения.Онооть познамочения. ошибо

Bagaimana untuk mengendalikan senario ralat dalam C++ dengan berkesan melalui pengendalian pengecualian? Bagaimana untuk mengendalikan senario ralat dalam C++ dengan berkesan melalui pengendalian pengecualian? Jun 02, 2024 pm 12:38 PM

Dalam C++, pengendalian pengecualian mengendalikan ralat dengan anggun melalui blok try-catch Jenis pengecualian biasa termasuk ralat masa jalan, ralat logik dan ralat luar sempadan. Ambil pengendalian ralat pembukaan fail sebagai contoh Apabila program gagal membuka fail, ia akan membuang pengecualian dan mencetak mesej ralat dan mengembalikan kod ralat melalui blok tangkapan, dengan itu mengendalikan ralat tanpa menamatkan program. Pengendalian pengecualian memberikan kelebihan seperti pemusatan pengendalian ralat, penyebaran ralat dan keteguhan kod.

Bagaimana untuk melakukan pengendalian ralat dan log masuk dalam reka bentuk kelas C++? Bagaimana untuk melakukan pengendalian ralat dan log masuk dalam reka bentuk kelas C++? Jun 02, 2024 am 09:45 AM

Ralat pengendalian dan log masuk dalam reka bentuk kelas C++ termasuk: Pengendalian pengecualian: menangkap dan mengendalikan pengecualian, menggunakan kelas pengecualian tersuai untuk memberikan maklumat ralat khusus. Kod ralat: Gunakan integer atau penghitungan untuk mewakili keadaan ralat dan mengembalikannya dalam nilai pulangan. Penegasan: Sahkan syarat pra dan pasca, dan buang pengecualian jika ia tidak dipenuhi. Pengelogan perpustakaan C++: pengelogan asas menggunakan std::cerr dan std::clog. Perpustakaan pengelogan luaran: Integrasikan perpustakaan pihak ketiga untuk ciri lanjutan seperti penapisan tahap dan putaran fail log. Kelas log tersuai: Buat kelas log anda sendiri, abstrak mekanisme asas dan sediakan antara muka biasa untuk merekodkan tahap maklumat yang berbeza.

Alat dan perpustakaan terbaik untuk pengendalian ralat PHP? Alat dan perpustakaan terbaik untuk pengendalian ralat PHP? May 09, 2024 pm 09:51 PM

Alat dan perpustakaan pengendalian ralat terbaik dalam PHP termasuk: Kaedah terbina dalam: set_error_handler() dan error_get_last() Kit alat pihak ketiga: Whoops (penyahpepijat dan pemformatan ralat) Perkhidmatan pihak ketiga: Sentry (pelaporan dan pemantauan ralat) Pihak ketiga perpustakaan: PHP-error-handler (pengelogan ralat tersuai dan jejak tindanan) dan Monolog (pengendali pengelogan ralat)

Pemprosesan tak segerak dalam pengendalian ralat fungsi golang Pemprosesan tak segerak dalam pengendalian ralat fungsi golang May 03, 2024 pm 03:06 PM

Dalam fungsi Go, pengendalian ralat tak segerak menggunakan saluran ralat untuk menghantar ralat daripada goroutin secara tak segerak. Langkah-langkah khusus adalah seperti berikut: Cipta saluran ralat. Mulakan goroutine untuk melaksanakan operasi dan menghantar ralat secara tidak segerak. Gunakan pernyataan pilih untuk menerima ralat daripada saluran. Mengendalikan ralat secara tidak segerak, seperti mencetak atau mengelog mesej ralat. Pendekatan ini meningkatkan prestasi dan kebolehskalaan kod serentak kerana pengendalian ralat tidak menyekat urutan panggilan dan pelaksanaan boleh dibatalkan.

Ralat mengendalikan strategi untuk ujian unit fungsi Go Ralat mengendalikan strategi untuk ujian unit fungsi Go May 02, 2024 am 11:21 AM

Dalam ujian unit fungsi Go, terdapat dua strategi utama untuk pengendalian ralat: 1. Wakilkan ralat sebagai nilai khusus jenis ralat, yang digunakan untuk menegaskan nilai yang dijangkakan 2. Gunakan saluran untuk menghantar ralat kepada fungsi ujian; yang sesuai untuk menguji kod serentak. Dalam kes praktikal, strategi nilai ralat digunakan untuk memastikan fungsi mengembalikan 0 untuk input negatif.

Amalan terbaik untuk pengendalian ralat dalam fungsi golang Amalan terbaik untuk pengendalian ralat dalam fungsi golang Apr 24, 2024 pm 05:24 PM

Amalan terbaik untuk pengendalian ralat dalam Go termasuk: menggunakan jenis ralat, sentiasa mengembalikan ralat, menyemak ralat, menggunakan pulangan berbilang nilai, menggunakan ralat sentinel dan menggunakan pembalut ralat. Contoh praktikal: Dalam pengendali permintaan HTTP, jika ReadDataFromDatabase mengembalikan ralat, kembalikan respons ralat 500.

Bagaimana untuk menggunakan pembungkus ralat Golang? Bagaimana untuk menggunakan pembungkus ralat Golang? Jun 03, 2024 pm 04:08 PM

Dalam Golang, pembalut ralat membolehkan anda membuat ralat baharu dengan menambahkan maklumat kontekstual kepada ralat asal. Ini boleh digunakan untuk menyatukan jenis ralat yang dilemparkan oleh perpustakaan atau komponen yang berbeza, memudahkan penyahpepijatan dan pengendalian ralat. Langkah-langkahnya adalah seperti berikut: Gunakan fungsi ralat. Balut untuk membalut ralat asal kepada ralat baharu. Ralat baharu mengandungi maklumat kontekstual daripada ralat asal. Gunakan fmt.Printf untuk mengeluarkan ralat yang dibalut, memberikan lebih konteks dan kebolehtindakan. Apabila mengendalikan pelbagai jenis ralat, gunakan fungsi ralat. Balut untuk menyatukan jenis ralat.

See all articles