sql >> Databasteknik >  >> RDS >> Mysql

Symfony3 hur man lagrar användarroller i databasen

Här är vad jag gjorde för att bli av med problemet,

Definiera roller i /app/config/security.yml enligt nedan,

role_hierarchy:
    ROLE_ADMIN:         [ROLE_ADMIN]
    ROLE_SUPER_ADMIN:   [ROLE_SUPER_ADMIN, ROLE_ALLOWED_TO_SWITCH]
    ROLE_TEACHER:       [ROLE_TEACHER]
    ROLE_STUDENT:       [ROLE_STUDENT]
    ROLE_PARENT:        [ROLE_PARENT]

i Controller, hämta rollerna från /app/config/security.yml med följande kod

$roles = $this->getParameter('security.role_hierarchy.roles');

och detta är koden till roller i formtypen,

$roles = $this->getParent('security.role_hierarchy.roles');

och sedan i formtype, (här är det multi select)

->add('roles', ChoiceType::class, array(
    'attr'  =>  array('class' => 'form-control',
    'style' => 'margin:5px 0;'),
    'choices' => 
    array
    (
        'ROLE_ADMIN' => array
        (
            'Yes' => 'ROLE_ADMIN',
        ),
        'ROLE_TEACHER' => array
        (
            'Yes' => 'ROLE_TEACHER'
        ),
        'ROLE_STUDENT' => array
        (
            'Yes' => 'ROLE_STUDENT'
        ),
        'ROLE_PARENT' => array
        (
            'Yes' => 'ROLE_PARENT'
        ),
    ) 
    ,
    'multiple' => true,
    'required' => true,
    )
)

Redigera Användarroller måste definieras i /app/config/security.yml enligt nedan

role_hierarchy:
    ROLE_ADMIN:         [ROLE_ADMIN]
    ROLE_SUPER_ADMIN:   [ROLE_SUPER_ADMIN, ROLE_ALLOWED_TO_SWITCH]
    ROLE_TEACHER:       [ROLE_TEACHER]
    ROLE_STUDENT:       [ROLE_STUDENT]
    ROLE_PARENT:        [ROLE_PARENT]


  1. Planering av diskutrymme för databaser

  2. 1064-fel i CREATE TABLE ... TYPE=MYISAM

  3. Utforska lagringsmotoralternativ för MariaDB

  4. Laravel 5.3:Syntaxfel eller åtkomstöverträdelse:1463 Icke-grupperande fält 'distans' används i HAVING-satsen