Langkah untuk melaksanakan pengurusan hak pengguna menggunakan rangka kerja Symfony

WBOY
Lepaskan: 2023-07-30 06:24:01
asal
1484 orang telah melayarinya

Langkah untuk menggunakan rangka kerja Symfony untuk melaksanakan pengurusan hak pengguna

Rangka kerja Symfony ialah rangka kerja pembangunan PHP yang berkuasa, yang boleh digunakan untuk membangunkan aplikasi web berkualiti tinggi dengan cepat. Apabila membangunkan aplikasi web, pengurusan hak pengguna adalah bahagian penting yang tidak boleh diabaikan. Artikel ini akan memperkenalkan langkah-langkah untuk melaksanakan pengurusan hak pengguna menggunakan rangka kerja Symfony, dengan contoh kod.

Langkah 1: Pasang rangka kerja Symfony
Mula-mula, kita perlu memasang rangka kerja Symfony dalam persekitaran setempat. Ia boleh dipasang melalui Komposer, jalankan arahan berikut:

composer create-project symfony/skeleton myproject
Salin selepas log masuk

Ini akan mencipta projek Symfony bernama myproject dalam direktori semasa.

Langkah 2: Konfigurasikan sambungan pangkalan data
Dalam projek Symfony, kami perlu mengkonfigurasi sambungan pangkalan data untuk menyimpan data berkaitan kebenaran pengguna. Dalam fail .env, tetapkan maklumat sambungan pangkalan data: .env文件中,设置数据库连接信息:

DATABASE_URL=mysql://your_username:your_password@localhost/your_database
Salin selepas log masuk

your_usernameyour_passwordyour_database替换为你自己的数据库用户名、密码和数据库名称。

第三步:创建用户实体类
在Symfony框架中,我们使用实体类来表示数据库中的数据结构。创建一个名为User.php的文件,定义一个用户实体类:

namespace AppEntity;

use SymfonyComponentSecurityCoreUserUserInterface;
use DoctrineORMMapping as ORM;

/**
 * @ORMEntity(repositoryClass="AppRepositoryUserRepository")
 */
class User implements UserInterface
{
    /**
     * @ORMId()
     * @ORMGeneratedValue()
     * @ORMColumn(type="integer")
     */
    private $id;

    /**
     * @ORMColumn(type="string", length=255, unique=true)
     */
    private $username;

    /**
     * ...
     * 添加其他属性和方法
     * ...
Salin selepas log masuk

第四步:配置安全设置
在Symfony框架中,安全组件负责处理用户认证和授权相关的任务。在config/packages/security.yaml文件中,配置安全设置:

security:
    encoders:
        AppEntityUser:
            algorithm: bcrypt

    providers:
        db_provider:
            entity:
                class: AppEntityUser
                property: username

    firewalls:
        main:
            anonymous: ~
            form_login:
                login_path: app_login
                check_path: app_login
            logout:
                path: app_logout
                target: app_home
            guard:
                authenticators:
                    - AppSecurityLoginFormAuthenticator
            remember_me:
                secret: '%kernel.secret%'

    access_control:
        - { path: ^/admin, roles: ROLE_ADMIN }
Salin selepas log masuk

第五步:创建自定义身份验证器
在Symfony框架中,我们可以创建自定义的身份验证器来处理用户登录认证。创建一个名为LoginFormAuthenticator.php的文件,定义一个自定义身份验证器:

namespace AppSecurity;

use SymfonyComponentSecurityCoreUserUserInterface;
use SymfonyComponentSecurityCoreUserUserProviderInterface;
use SymfonyComponentSecurityGuardAuthenticatorAbstractFormLoginAuthenticator;
use SymfonyComponentSecurityCoreEncoderUserPasswordEncoderInterface;
use SymfonyComponentHttpFoundationRequest;
use SymfonyComponentSecurityCoreAuthenticationTokenTokenInterface;

class LoginFormAuthenticator extends AbstractFormLoginAuthenticator
{
    private $encoder;
    private $router;

    public function __construct(UserPasswordEncoderInterface $encoder, RouterInterface $router)
    {
        $this->encoder = $encoder;
        $this->router = $router;
    }

    public function supports(Request $request)
    {
        return $request->attributes->get('_route') === 'app_login' && $request->isMethod('POST');
    }

    public function getCredentials(Request $request)
    {
        $credentials = [
            'username' => $request->request->get('username'),
            'password' => $request->request->get('password'),
        ];

        $request->getSession()->set(
            Security::LAST_USERNAME,
            $credentials['username']
        );

        return $credentials;
    }

    public function getUser($credentials, UserProviderInterface $userProvider)
    {
        $username = $credentials['username'];

        return $userProvider->loadUserByUsername($username);
    }

    public function checkCredentials($credentials, UserInterface $user)
    {
        $password = $credentials['password'];

        if ($this->encoder->isPasswordValid($user, $password)) {
            return true;
        }

        return false;
    }

    public function onAuthenticationSuccess(Request $request, TokenInterface $token, $providerKey)
    {
        return new RedirectResponse($this->router->generate('app_home'));
    }

    protected function getLoginUrl()
    {
        return $this->router->generate('app_login');
    }
}
Salin selepas log masuk

第六步:创建控制器和路由
在Symfony框架中,我们可以创建控制器和路由来处理用户认证和授权相关的任务。创建一个名为SecurityController.php的文件,定义一个控制器类:

namespace AppController;

use SymfonyComponentRoutingAnnotationRoute;
use SymfonyBundleFrameworkBundleControllerAbstractController;
use SymfonyComponentSecurityHttpAuthenticationAuthenticationUtils;

class SecurityController extends AbstractController
{
    /**
     * @Route("/login", name="app_login")
     */
    public function login(AuthenticationUtils $authenticationUtils)
    {
        $error = $authenticationUtils->getLastAuthenticationError();
        $lastUsername = $authenticationUtils->getLastUsername();

        return $this->render('security/login.html.twig', [
            'last_username' => $lastUsername,
            'error' => $error,
        ]);
    }

    /**
     * @Route("/logout", name="app_logout")
     */
    public function logout()
    {
        throw new Exception('This will never be called.');
    }
}
Salin selepas log masuk

config/routes.yaml

app_login:
    path: /login
    controller: AppControllerSecurityController::login

app_logout:
    path: /logout
    controller: AppControllerSecurityController::logout
Salin selepas log masuk
Ganti nama_pengguna_anda, kata laluan_anda dan pangkalan data_anda dengan Nama pengguna pangkalan data, kata laluan dan nama pangkalan data anda sendiri.

Langkah 3: Buat kelas entiti pengguna

Dalam rangka kerja Symfony, kami menggunakan kelas entiti untuk mewakili struktur data dalam pangkalan data. Buat fail bernama User.php dan tentukan kelas entiti pengguna:

rrreee🎜Langkah 4: Konfigurasikan tetapan keselamatan🎜Dalam rangka kerja Symfony, komponen keselamatan bertanggungjawab untuk mengendalikan tugas yang berkaitan dengan pengesahan dan kebenaran pengguna . Dalam fail config/packages/security.yaml, konfigurasikan tetapan keselamatan: 🎜rrreee🎜Langkah 5: Cipta pengesah tersuai🎜Dalam rangka kerja Symfony, kami boleh mencipta pengesah tersuai Untuk mengendalikan pengesahan log masuk pengguna . Cipta fail yang dipanggil LoginFormAuthenticator.php dan tentukan pengesah tersuai: 🎜rrreee🎜Langkah 6: Buat pengawal dan laluan🎜Dalam rangka kerja Symfony, kami boleh mencipta pengawal dan laluan Untuk mengendalikan tugas yang berkaitan dengan pengesahan pengguna dan kebenaran. Buat fail bernama SecurityController.php dan tentukan kelas pengawal: 🎜rrreee🎜Dalam fail config/routes.yaml, tentukan laluan: 🎜rrreee🎜Pada ketika ini, Kami telah menyelesaikan langkah-langkah melaksanakan pengurusan hak pengguna menggunakan rangka kerja Symfony. Melalui contoh kod di atas, kita boleh belajar cara mengkonfigurasi sambungan pangkalan data, mencipta kelas entiti, mengkonfigurasi tetapan keselamatan, mencipta pengesah tersuai dan mencipta pengawal dan laluan dalam rangka kerja Symfony. 🎜🎜Sudah tentu, ini hanya contoh mudah. Dalam pembangunan sebenar, mungkin perlu untuk memproses lagi pengurusan peranan dan kebenaran pengguna, seperti mencipta kelas entiti peranan, jadual pengesahan kebenaran, dsb. Walau bagaimanapun, langkah di atas boleh digunakan sebagai titik permulaan untuk membantu kami melaksanakan pengurusan hak pengguna dalam projek Symfony. Harap artikel ini dapat membantu anda! 🎜

Atas ialah kandungan terperinci Langkah untuk melaksanakan pengurusan hak pengguna menggunakan rangka kerja Symfony. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Label berkaitan:
sumber:php.cn
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
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan