Rumah pembangunan bahagian belakang tutorial php Amalan terbaik pengaturcaraan PHP untuk mencegah serangan CSRF

Amalan terbaik pengaturcaraan PHP untuk mencegah serangan CSRF

Jul 05, 2023 pm 04:41 PM
pengaturcaraan php amalan terbaik Serangan anti-csrf

Amalan Terbaik untuk Pengaturcaraan PHP untuk Mencegah Serangan CSRF

CSRF (Pemalsuan Permintaan Rentas Tapak) ialah kaedah serangan rangkaian biasa Penyerang menyamar permintaan daripada pengguna yang sah untuk membolehkan pengguna melakukan operasi berniat jahat tanpa pengetahuan mereka. Untuk melindungi pengguna dan aplikasi, pembangun perlu mengambil beberapa langkah untuk mencegah serangan CSRF. Artikel ini akan memperkenalkan beberapa amalan terbaik dalam pengaturcaraan PHP untuk mencegah serangan CSRF dan menyediakan beberapa contoh kod.

  1. Gunakan Token CSRF
    Menggunakan token CSRF ialah salah satu cara yang paling biasa dan paling berkesan untuk mencegah serangan CSRF. Token unik dijana setiap sesi pengguna dan disertakan dengan setiap permintaan penyerahan borang. Apabila pelayan memproses permintaan, ia menyemak sama ada token itu sah. Jika token tidak sah, pelayan boleh menolak permintaan atau melakukan tindakan tersuai lain.

Berikut ialah contoh mudah menggunakan token CSRF:

// 生成CSRF令牌
function generateCSRFToken() {
    $token = bin2hex(random_bytes(32));
    $_SESSION['csrf_token'] = $token;
    return $token;
}

// 在表单中包含CSRF令牌
function renderForm() {
    $csrfToken = generateCSRFToken();
    echo '<form action="process.php" method="post">';
    echo '<input type="hidden" name="csrf_token" value="' . $csrfToken . '">';
    echo '<input type="text" name="username">';
    echo '<input type="password" name="password">';
    echo '<input type="submit" value="Submit">';
    echo '</form>';
}

// 处理表单提交请求
function processForm() {
    if ($_POST['csrf_token'] !== $_SESSION['csrf_token']) {
        // 令牌无效,处理错误
        echo 'Invalid CSRF token!';
        return;
    }
    
    // 处理表单提交数据
    $username = $_POST['username'];
    $password = $_POST['password'];
    
    // 执行其他操作
    // ...
}

// 调用函数
renderForm();
processForm();
Salin selepas log masuk

Dalam kod di atas, fungsi generateCSRFToken bertanggungjawab untuk menjana token CSRF dan menyimpannya dalam sesi pengguna. Fungsi renderForm bertanggungjawab untuk memberikan borang dan memasukkan token CSRF dalam medan tersembunyi. Fungsi processForm bertanggungjawab untuk memproses permintaan penyerahan borang dan mengesahkan kesahihan token CSRF sebelum diproses. generateCSRFToken函数负责生成CSRF令牌,并将其存储在用户的会话中。renderForm函数负责渲染表单,并在隐藏的字段中包含CSRF令牌。processForm函数负责处理表单提交请求,并在处理前验证CSRF令牌的有效性。

  1. 验证请求来源
    除了使用CSRF令牌外,还可以通过验证请求的来源来防止CSRF攻击。在处理请求时,服务器可以检查请求头中的Referer字段,确保请求是来自同一域名的。如果Referer字段为空或不是期望的域名,服务器可以拒绝请求或执行其他自定义操作。

以下是一个简单的验证请求来源的示例:

function processRequest() {
    $expectedDomain = 'https://www.example.com';
    
    if (!isset($_SERVER['HTTP_REFERER']) || strpos($_SERVER['HTTP_REFERER'], $expectedDomain) !== 0) {
        // 请求来源无效,处理错误
        echo 'Invalid request source!';
        return;
    }
    
    // 处理请求
    // ...
}
Salin selepas log masuk

在上述代码中,processRequest函数负责处理请求,并验证请求来源。通过检查请求头中的Referer

    Sahkan sumber permintaan

    Selain menggunakan token CSRF, anda juga boleh menghalang serangan CSRF dengan mengesahkan sumber permintaan. Apabila memproses permintaan, pelayan boleh menyemak medan Perujuk dalam pengepala permintaan untuk memastikan permintaan itu datang daripada nama domain yang sama. Jika medan Perujuk kosong atau bukan nama domain yang diharapkan, pelayan boleh menolak permintaan atau melakukan tindakan tersuai yang lain.

    Berikut ialah contoh mudah untuk mengesahkan sumber permintaan:

    rrreee🎜Dalam kod di atas, fungsi processRequest bertanggungjawab untuk memproses permintaan dan mengesahkan sumber permintaan. Pelayan boleh menentukan kesahihan permintaan dengan menyemak sama ada medan Perujuk dalam pengepala permintaan bermula dengan nama domain yang dijangkakan. 🎜🎜Ringkasan🎜Serangan CSRF menimbulkan ancaman tertentu terhadap keselamatan aplikasi web, tetapi dengan mengamalkan amalan pengaturcaraan yang sesuai, pembangun boleh menghalang serangan sedemikian dengan berkesan. Artikel ini merangkumi dua amalan terbaik dalam pengaturcaraan PHP: menggunakan token CSRF dan mengesahkan asal permintaan. Kaedah ini boleh membantu pembangun meningkatkan keselamatan aplikasi web dan melindungi data pengguna dan privasi. 🎜🎜Tetapi harus diingat bahawa bergantung pada langkah-langkah ini sahaja mungkin tidak sepenuhnya menghalang serangan CSRF. Pembangun juga harus mengambil langkah keselamatan lain, seperti menggunakan HTTPS untuk menyulitkan komunikasi dan menyediakan pengurusan sesi selamat untuk pengguna. Paling penting, pembangun harus sentiasa memberi perhatian kepada maklumat terkini tentang kelemahan keselamatan dan segera membetulkan serta menaik taraf aplikasi untuk mengekalkan keselamatan aplikasi. 🎜

Atas ialah kandungan terperinci Amalan terbaik pengaturcaraan PHP untuk mencegah serangan CSRF. 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 尊渡假赌尊渡假赌尊渡假赌
Akan R.E.P.O. Ada Crossplay?
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)

Baris format PHP ke CSV dan tulis penuding fail Baris format PHP ke CSV dan tulis penuding fail Mar 22, 2024 am 09:00 AM

Artikel ini akan menerangkan secara terperinci bagaimana PHP memformat baris ke dalam CSV dan menulis penunjuk fail saya rasa ia agak praktikal, jadi saya berkongsi dengan anda sebagai rujukan saya harap anda boleh memperoleh sesuatu selepas membaca artikel ini. Format baris ke CSV dan tulis ke penuding fail Langkah 1: Buka penuding fail $file=fopen("path/to/file.csv","w"); kepada rentetan CSV. Fungsi ini menerima parameter berikut: $fail: penuding fail $medan: medan CSV sebagai tatasusunan $pembatas: pembatas medan (pilihan) $kepungan: petikan medan (

PHP menukar umask semasa PHP menukar umask semasa Mar 22, 2024 am 08:41 AM

Artikel ini akan menerangkan secara terperinci tentang menukar umask semasa dalam PHP Editor berpendapat ia agak praktikal, jadi saya berkongsi dengan anda sebagai rujukan saya harap anda boleh memperoleh sesuatu selepas membaca artikel ini. Gambaran keseluruhan PHP yang menukar umask semasa umask ialah fungsi php yang digunakan untuk menetapkan kebenaran fail lalai untuk fail dan direktori yang baru dibuat. Ia menerima satu hujah, iaitu nombor perlapanan yang mewakili kebenaran untuk menyekat. Sebagai contoh, untuk menghalang kebenaran menulis pada fail yang baru dibuat, anda akan menggunakan 002. Kaedah menukar umask Terdapat dua cara untuk menukar umask semasa dalam PHP: Menggunakan fungsi umask(): Fungsi umask() menukar secara langsung umask semasa. Sintaksnya ialah: intumas

Amalan terbaik untuk menukar rentetan kepada nombor titik terapung dalam PHP Amalan terbaik untuk menukar rentetan kepada nombor titik terapung dalam PHP Mar 28, 2024 am 08:18 AM

Menukar rentetan kepada nombor titik terapung dalam PHP ialah keperluan biasa semasa proses pembangunan Contohnya, medan jumlah yang dibaca daripada pangkalan data adalah daripada jenis rentetan dan perlu ditukar kepada nombor titik terapung untuk pengiraan berangka. Dalam artikel ini, kami akan memperkenalkan amalan terbaik untuk menukar rentetan kepada nombor titik terapung dalam PHP dan memberikan contoh kod khusus. Pertama sekali, kita perlu menjelaskan dengan jelas bahawa terdapat dua cara utama untuk menukar rentetan kepada nombor titik terapung dalam PHP: menggunakan penukaran jenis (float) atau menggunakan fungsi (floatval). Di bawah ini kami akan memperkenalkan kedua-dua ini

Apakah amalan terbaik untuk rangka kerja golang? Apakah amalan terbaik untuk rangka kerja golang? Jun 01, 2024 am 10:30 AM

Apabila menggunakan rangka kerja Go, amalan terbaik termasuk: Pilih rangka kerja ringan seperti Gin atau Echo. Ikuti prinsip RESTful dan gunakan kata kerja dan format HTTP standard. Manfaatkan perisian tengah untuk memudahkan tugas seperti pengesahan dan pengelogan. Kendalikan ralat dengan betul, menggunakan jenis ralat dan mesej yang bermakna. Tulis ujian unit dan integrasi untuk memastikan aplikasi berfungsi dengan baik.

Terokai amalan terbaik untuk lekukan dalam Go Terokai amalan terbaik untuk lekukan dalam Go Mar 21, 2024 pm 06:48 PM

Dalam bahasa Go, lekukan yang baik adalah kunci kepada kebolehbacaan kod. Semasa menulis kod, gaya lekukan bersatu boleh menjadikan kod lebih jelas dan lebih mudah difahami. Artikel ini akan meneroka amalan terbaik untuk lekukan dalam bahasa Go dan memberikan contoh kod khusus. Gunakan ruang dan bukannya tab In Go, adalah disyorkan untuk menggunakan ruang dan bukannya tab untuk lekukan. Ini boleh mengelakkan masalah tetapan taip yang disebabkan oleh lebar tab yang tidak konsisten dalam editor yang berbeza. Bilangan ruang untuk lekukan bahasa Go secara rasmi mengesyorkan penggunaan 4 ruang sebagai bilangan ruang untuk lekukan. Ini membolehkan kod menjadi

Amalan Terbaik PHP: Alternatif untuk Mengelak Penyata Goto Diterokai Amalan Terbaik PHP: Alternatif untuk Mengelak Penyata Goto Diterokai Mar 28, 2024 pm 04:57 PM

Amalan Terbaik PHP: Alternatif untuk Mengelakkan Pernyataan Goto Diterokai Dalam pengaturcaraan PHP, pernyataan goto ialah struktur kawalan yang membenarkan lompatan terus ke lokasi lain dalam atur cara. Walaupun pernyataan goto boleh memudahkan struktur kod dan kawalan aliran, penggunaannya secara meluas dianggap sebagai amalan buruk kerana ia boleh menyebabkan kekeliruan kod, mengurangkan kebolehbacaan dan kesukaran penyahpepijatan. Dalam pembangunan sebenar, untuk mengelakkan penggunaan pernyataan goto, kita perlu mencari kaedah alternatif untuk mencapai fungsi yang sama. Artikel ini akan meneroka beberapa alternatif,

Perbandingan mendalam: amalan terbaik antara rangka kerja Java dan rangka kerja bahasa lain Perbandingan mendalam: amalan terbaik antara rangka kerja Java dan rangka kerja bahasa lain Jun 04, 2024 pm 07:51 PM

Rangka kerja Java sesuai untuk projek yang merentas platform, kestabilan dan kebolehskalaan adalah penting. Untuk projek Java, Spring Framework digunakan untuk suntikan pergantungan dan pengaturcaraan berorientasikan aspek, dan amalan terbaik termasuk menggunakan SpringBean dan SpringBeanFactory. Hibernate digunakan untuk pemetaan hubungan objek, dan amalan terbaik ialah menggunakan HQL untuk pertanyaan kompleks. JakartaEE digunakan untuk pembangunan aplikasi perusahaan, dan amalan terbaik adalah menggunakan EJB untuk logik perniagaan teragih.

PHP menentukan sama ada kunci yang ditentukan wujud dalam tatasusunan PHP menentukan sama ada kunci yang ditentukan wujud dalam tatasusunan Mar 21, 2024 pm 09:21 PM

Artikel ini akan menerangkan secara terperinci bagaimana PHP menentukan sama ada kunci yang ditentukan wujud dalam tatasusunan Editor berpendapat ia sangat praktikal, jadi saya berkongsi dengan anda sebagai rujukan saya harap anda boleh memperoleh sesuatu selepas membaca artikel ini. PHP menentukan sama ada kunci yang ditentukan wujud dalam tatasusunan: Dalam PHP, terdapat banyak cara untuk menentukan sama ada kunci yang ditentukan wujud dalam tatasusunan: 1. Gunakan fungsi isset(): isset($array["key"]) Fungsi ini mengembalikan nilai Boolean, benar jika kunci yang ditentukan wujud, palsu sebaliknya. 2. Gunakan fungsi array_key_exists(): array_key_exists("key",$arr

See all articles