Jadual Kandungan
欢迎,
Rumah pembangunan bahagian belakang tutorial php Bagaimana untuk melaksanakan pengesahan dan kebenaran pengguna dalam pembangunan fungsi back-end PHP?

Bagaimana untuk melaksanakan pengesahan dan kebenaran pengguna dalam pembangunan fungsi back-end PHP?

Aug 09, 2023 am 10:17 AM
php membenarkan Pengesahan pengguna

Bagaimana untuk melaksanakan pengesahan dan kebenaran pengguna dalam pembangunan fungsi back-end PHP?

Bagaimana untuk melaksanakan pengesahan dan kebenaran pengguna dalam pembangunan fungsi back-end PHP?

Dalam pembangunan aplikasi web, pengesahan dan kebenaran pengguna adalah sangat penting. Pengesahan pengguna digunakan untuk mengesahkan identiti pengguna, dan kebenaran digunakan untuk menyekat akses pengguna kepada sumber. Artikel ini akan memperkenalkan cara menggunakan PHP untuk melaksanakan fungsi pengesahan dan kebenaran pengguna.

Pengesahan Pengguna

Pengesahan pengguna ialah proses mengesahkan identiti pengguna untuk memastikan hanya pengguna yang sah boleh mengakses sumber sistem. Kaedah pengesahan pengguna biasa termasuk pengesahan asas, pengesahan ringkasan, pengesahan borang dan pengesahan token. Berikut ialah contoh penggunaan pengesahan borang:

<?php
session_start();

// 定义用户信息
$users = [
    'admin' => 'password123',
    'user1' => '123456',
];

if ($_SERVER['REQUEST_METHOD'] === 'POST') {
    $username = $_POST['username'];
    $password = $_POST['password'];

    // 验证用户名和密码
    if (isset($users[$username]) && $users[$username] === $password) {
        $_SESSION['username'] = $username;
        header('Location: /home.php');
        exit;
    } else {
        echo '登录失败';
    }
}
?>

<!DOCTYPE html>
<html>
<head>
    <title>用户登录</title>
</head>
<body>
    <form action="login.php" method="post">
        <label for="username">用户名:</label>
        <input type="text" name="username" id="username" required><br>

        <label for="password">密码:</label>
        <input type="password" name="password" id="password" required><br>

        <input type="submit" value="登录">
    </form>
</body>
</html>
Salin selepas log masuk

Dalam contoh di atas, selepas pengguna memasukkan nama pengguna dan kata laluan, input pengguna disahkan dan dibandingkan dengan maklumat pengguna pratetap Jika pengesahan diluluskan, nama pengguna disimpan dalam fail sesi , dan ubah hala halaman ke halaman utama (home.php).

Keizinan pengguna

Keizinan pengguna adalah berdasarkan pengesahan pengguna dan mengawal akses pengguna kepada sumber sistem. Kaedah kebenaran biasa termasuk kawalan akses berasaskan peranan (RBAC) dan kawalan akses berasaskan kebenaran (RBAC).

Berikut ialah contoh penggunaan kawalan akses berasaskan peranan:

<?php
session_start();

// 定义用户和角色关系
$roles = [
    'admin' => ['home', 'profile', 'settings'],
    'user' => ['home', 'profile'],
];

// 检查用户是否已登录
if (!isset($_SESSION['username'])) {
    header('Location: /login.php');
    exit;
}

// 获取用户角色
$username = $_SESSION['username'];
if (isset($roles[$username])) {
    $userRoles = $roles[$username];
} else {
    $userRoles = [];
}

// 检查用户是否有访问权限
function hasAccess($page, $roles) {
    foreach ($roles as $role) {
        if (in_array($page, $role)) {
            return true;
        }
    }

    return false;
}

// 验证访问权限
$page = isset($_GET['page']) ? $_GET['page'] : 'home';
if (!hasAccess($page, $userRoles)) {
    echo '无权访问该页面';
    exit;
}
?>

<!DOCTYPE html>
<html>
<head>
    <title>用户授权示例</title>
</head>
<body>
    <h1 id="欢迎-php-echo-username">欢迎, <?php echo $username; ?></h1>

    <ul>
        <?php if (hasAccess('home', $userRoles)): ?>
            <li><a href="/home.php">首页</a></li>
        <?php endif; ?>

        <?php if (hasAccess('profile', $userRoles)): ?>
            <li><a href="/profile.php">个人资料</a></li>
        <?php endif; ?>

        <?php if (hasAccess('settings', $userRoles)): ?>
            <li><a href="/settings.php">设置</a></li>
        <?php endif; ?>
    </ul>
</body>
</html>
Salin selepas log masuk

Dalam contoh di atas, kami menyimpan maklumat peranan pengguna melalui fail sesi. Mula-mula, tentukan sama ada pengguna dilog masuk. Jika tidak, ubah hala halaman ke halaman log masuk jika log masuk, semak sama ada pengguna mempunyai kebenaran untuk mengakses halaman yang ditentukan, berikan gesaan yang sepadan. Pada masa yang sama, pautan berfungsi yang dipaparkan pada halaman ditentukan berdasarkan maklumat peranan pengguna.

Ringkasan

Melalui contoh di atas, kami mempelajari cara menggunakan PHP untuk melaksanakan fungsi pengesahan dan kebenaran pengguna. Pengesahan pengguna memastikan bahawa hanya pengguna yang sah dibenarkan untuk mengakses sistem dengan mengesahkan identiti pengguna. Keizinan pengguna mengawal akses pengguna kepada sumber sistem dan mengehadkan pengguna untuk mengakses halaman atau fungsi sahaja yang mereka mempunyai kebenaran.

Perlu diingatkan bahawa dalam pembangunan aplikasi sebenar, untuk meningkatkan keselamatan, kami juga boleh menambah beberapa mekanisme keselamatan lain, seperti menambah cincang masin untuk menyimpan kata laluan, menggunakan HTTPS untuk menghantar maklumat pengguna, dsb. Pada masa yang sama, reka bentuk dan pengurusan pangkalan data juga merupakan salah satu pautan penting dalam proses pengesahan dan kebenaran pengguna.

Saya berharap kandungan di atas dapat membantu anda memahami dengan lebih baik dan menggunakan pengetahuan yang berkaitan tentang pengesahan dan kebenaran pengguna, serta mencapai pengurusan hak pengguna yang lebih selamat dan munasabah dalam pembangunan web masa hadapan anda.

Atas ialah kandungan terperinci Bagaimana untuk melaksanakan pengesahan dan kebenaran pengguna dalam pembangunan fungsi back-end PHP?. 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)
3 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Tetapan grafik terbaik
3 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Cara Memperbaiki Audio Jika anda tidak dapat mendengar sesiapa
3 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25: Cara Membuka Segala -galanya Di Myrise
4 minggu 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)

Panduan Pemasangan dan Naik Taraf PHP 8.4 untuk Ubuntu dan Debian Panduan Pemasangan dan Naik Taraf PHP 8.4 untuk Ubuntu dan Debian Dec 24, 2024 pm 04:42 PM

PHP 8.4 membawa beberapa ciri baharu, peningkatan keselamatan dan peningkatan prestasi dengan jumlah penamatan dan penyingkiran ciri yang sihat. Panduan ini menerangkan cara memasang PHP 8.4 atau naik taraf kepada PHP 8.4 pada Ubuntu, Debian, atau terbitan mereka

Tarikh dan Masa CakePHP Tarikh dan Masa CakePHP Sep 10, 2024 pm 05:27 PM

Untuk bekerja dengan tarikh dan masa dalam cakephp4, kami akan menggunakan kelas FrozenTime yang tersedia.

Bincangkan CakePHP Bincangkan CakePHP Sep 10, 2024 pm 05:28 PM

CakePHP ialah rangka kerja sumber terbuka untuk PHP. Ia bertujuan untuk menjadikan pembangunan, penggunaan dan penyelenggaraan aplikasi lebih mudah. CakePHP adalah berdasarkan seni bina seperti MVC yang berkuasa dan mudah difahami. Model, Pandangan dan Pengawal gu

Muat naik Fail CakePHP Muat naik Fail CakePHP Sep 10, 2024 pm 05:27 PM

Untuk mengusahakan muat naik fail, kami akan menggunakan pembantu borang. Di sini, adalah contoh untuk muat naik fail.

Pengesah Mencipta CakePHP Pengesah Mencipta CakePHP Sep 10, 2024 pm 05:26 PM

Pengesah boleh dibuat dengan menambah dua baris berikut dalam pengawal.

Cara Menyediakan Kod Visual Studio (Kod VS) untuk Pembangunan PHP Cara Menyediakan Kod Visual Studio (Kod VS) untuk Pembangunan PHP Dec 20, 2024 am 11:31 AM

Kod Visual Studio, juga dikenali sebagai Kod VS, ialah editor kod sumber percuma — atau persekitaran pembangunan bersepadu (IDE) — tersedia untuk semua sistem pengendalian utama. Dengan koleksi sambungan yang besar untuk banyak bahasa pengaturcaraan, Kod VS boleh menjadi c

Panduan Ringkas CakePHP Panduan Ringkas CakePHP Sep 10, 2024 pm 05:27 PM

CakePHP ialah rangka kerja MVC sumber terbuka. Ia menjadikan pembangunan, penggunaan dan penyelenggaraan aplikasi lebih mudah. CakePHP mempunyai beberapa perpustakaan untuk mengurangkan beban tugas yang paling biasa.

Bagaimana anda menghuraikan dan memproses HTML/XML dalam PHP? Bagaimana anda menghuraikan dan memproses HTML/XML dalam PHP? Feb 07, 2025 am 11:57 AM

Tutorial ini menunjukkan cara memproses dokumen XML dengan cekap menggunakan PHP. XML (bahasa markup extensible) adalah bahasa markup berasaskan teks yang serba boleh yang direka untuk pembacaan manusia dan parsing mesin. Ia biasanya digunakan untuk penyimpanan data

See all articles