Php 注册时将角色附加到用户laravel 5.4

Php 注册时将角色附加到用户laravel 5.4,php,laravel,laravel-5,Php,Laravel,Laravel 5,我尝试将我的一个角色附加为用户注册时的默认角色,我尝试了不同的方式,如本文,但没有任何效果: 如果您想帮助我编码,我尝试在注册表中附加的角色是name=>user和id=>3 这是我的登记表: <?php namespace App\Http\Controllers\Auth; use App\User; use App\Role; use App\Http\Controllers\Controller; use Illuminate\Support\Facades\Validator

我尝试将我的一个角色附加为用户注册时的默认角色,我尝试了不同的方式,如本文,但没有任何效果:

如果您想帮助我编码,我尝试在注册表中附加的角色是
name=>user
id=>3

这是我的登记表:

<?php

namespace App\Http\Controllers\Auth;

use App\User;
use App\Role;
use App\Http\Controllers\Controller;
use Illuminate\Support\Facades\Validator;
use Illuminate\Foundation\Auth\RegistersUsers;

class RegisterController extends Controller
{
    /*
    |--------------------------------------------------------------------------
    | Register Controller
    |--------------------------------------------------------------------------
    |
    | This controller handles the registration of new users as well as their
    | validation and creation. By default this controller uses a trait to
    | provide this functionality without requiring any additional code.
    |
    */

    use RegistersUsers;

    /**
     * Where to redirect users after registration.
     *
     * @var string
     */
    protected $redirectTo = '/home';

    /**
     * Create a new controller instance.
     *
     * @return void
     */
    public function __construct()
    {
        $this->middleware('guest');
    }

    /**
     * Get a validator for an incoming registration request.
     *
     * @param  array  $data
     * @return \Illuminate\Contracts\Validation\Validator
     */
    protected function validator(array $data)
    {
        return Validator::make($data, [
            'fname' => 'required|string|max:255',
            'lname' => 'required|string|max:255',
            'username' => 'required|string|min:4|max:255|unique:users',
            'gender' => 'required',
            'city' => 'sometimes|string|max:255',
            'province' => 'sometimes|string|max:255',
            'country' => 'sometimes|string|max:255',
            'phone' => 'sometimes|string|max:255',
            'email' => 'required|string|email|max:255|unique:users',
            'password' => 'required|string|min:6|confirmed',
        ]);
    }

    /**
     * Create a new user instance after a valid registration.
     *
     * @param  array  $data
     * @return User
     */
    protected function create(array $data)
    {
        return User::create([
            'fname' => $data['fname'],
            'lname' => $data['lname'],
            'username' => $data['username'],
            'gender' => $data['gender'],
            'city' => $data['city'],
            'province' => $data['province'],
            'country' => $data['country'],
            'phone' => $data['phone'],
            'email' => $data['email'],
            'password' => bcrypt($data['password']),
        ]);
    }
}

您是否使用
php artisan make:auth
设置身份验证

我在app\Http\Controllers\Auth\RegisterController.php中添加了以下内容,以便为所有用户分配默认角色“user”

protected function create(array $data)
{
    $role = Role::where('name', 'user')->first();

    $user = User::create([
        'name' => $data['name'],
        'email' => $data['email'],
        'password' => bcrypt($data['password']),
    ]);

    $user->assignRole($role);

    return $user;
}
以及User.php中的以下内容

public function roles()
{
    return $this->belongsToMany(Role::class);
}

public function assignRole(Role $role)
{
    return $this->roles()->save($role);
}

您是否使用php artisan make:auth设置身份验证

我在app\Http\Controllers\Auth\RegisterController.php中添加了以下内容,以便为所有用户分配默认角色“user”

protected function create(array $data)
{
    $role = Role::where('name', 'user')->first();

    $user = User::create([
        'name' => $data['name'],
        'email' => $data['email'],
        'password' => bcrypt($data['password']),
    ]);

    $user->assignRole($role);

    return $user;
}
以及User.php中的以下内容

public function roles()
{
    return $this->belongsToMany(Role::class);
}

public function assignRole(Role $role)
{
    return $this->roles()->save($role);
}

下面是如何用一种简单的方式做到这一点

首先,您必须有如下请求

// $request->id ( integer )
// $request->fname ( string )
// $request->lname ( string )
// $request->roles ( array )(assuming user and role have many to many relation)
所以。。给定输入,函数如下

protected function roleValidator(array $data)
{
    return Validator::make($data, [
        'roles' =>  'required|array|min:1',
    ]);
}

public function editUser(Request $request)
{
    // FIRST VALIDATE INPUT ROLES
    $roles = $request->only('roles');
    // CHECK IF HAVE ATLEAST ONE HAS BEEN SELECTED
    $roleValidate = $this->roleValidator($roles);
    if (!$roleValidate->fails())
    {
        $request->roles = array_unique($request->roles);
        $roles = Role::orderBy('id','asc')->get(['id']);
        $roleList = array();
        foreach($roles as $role) { array_push($roleList,$role->id); }
        // CHECK IF ALL INPUTS ARE VALID ROLES IN THE DB
        if(count(array_intersect($request->roles, $roleList)) == count($request->roles))
        {
            // VALIDATE YOUR PROFILE
            .....
            $user = User::find($request->userID);
            $user->fname = $request->fname;
            $user->lname= $request->fname;
            $user->roles()->sync($request->roles);
            $user->save();
        }
        else
        {
            // INVALID ROLE DETECTED!
        }
    }
    else
    {
        // SHOW $roleValidate->errors()->all()
    }
}

下面是如何用一种简单的方式做到这一点

首先,您必须有如下请求

// $request->id ( integer )
// $request->fname ( string )
// $request->lname ( string )
// $request->roles ( array )(assuming user and role have many to many relation)
所以。。给定输入,函数如下

protected function roleValidator(array $data)
{
    return Validator::make($data, [
        'roles' =>  'required|array|min:1',
    ]);
}

public function editUser(Request $request)
{
    // FIRST VALIDATE INPUT ROLES
    $roles = $request->only('roles');
    // CHECK IF HAVE ATLEAST ONE HAS BEEN SELECTED
    $roleValidate = $this->roleValidator($roles);
    if (!$roleValidate->fails())
    {
        $request->roles = array_unique($request->roles);
        $roles = Role::orderBy('id','asc')->get(['id']);
        $roleList = array();
        foreach($roles as $role) { array_push($roleList,$role->id); }
        // CHECK IF ALL INPUTS ARE VALID ROLES IN THE DB
        if(count(array_intersect($request->roles, $roleList)) == count($request->roles))
        {
            // VALIDATE YOUR PROFILE
            .....
            $user = User::find($request->userID);
            $user->fname = $request->fname;
            $user->lname= $request->fname;
            $user->roles()->sync($request->roles);
            $user->save();
        }
        else
        {
            // INVALID ROLE DETECTED!
        }
    }
    else
    {
        // SHOW $roleValidate->errors()->all()
    }
}
资料来源:


来源:

当我使用你的代码时,它是在分配用户角色,但它不是在重定向仪表板。我遇到了一个关系错误,因此用下面提到的方法解决了。公共函数roles(){return$this->belongToMany(Role::class,'user_roles);}当我使用你的代码时,它正在分配用户角色,但它没有重定向仪表板。我遇到了一个关系错误,因此用下面提到的方法解决了。公共函数角色(){return$this->belongToMany(角色::类,'user_角色);}