Php 检查用户权限以执行某些操作
我正在创建laravel上的用户权限。在我的数据库中,我有一个id为/user\u id/model/write/read/delete的表 最后三个权限是枚举类型:on和off 在我的用户模型中,im编写了要设置的方法:Php 检查用户权限以执行某些操作,php,laravel-4,Php,Laravel 4,我正在创建laravel上的用户权限。在我的数据库中,我有一个id为/user\u id/model/write/read/delete的表 最后三个权限是枚举类型:on和off 在我的用户模型中,im编写了要设置的方法: protected $models = ['dashboard', 'preferences']; public function setPermissions($input=false) { foreach($th
protected $models = ['dashboard', 'preferences'];
public function setPermissions($input=false)
{
foreach($this->models as $model) {
$read = (isset($input[$model]['read']) ? 'on' : 'off');
$write = (isset($input[$model]['write']) ? 'on' : 'off');
$delete = (isset($input[$model]['delete']) ? 'on' : 'off');
$perms = Permissions::firstOrNew([
'user_id' => $this->id,
'model' => $model,
]);
$perms->read = $read;
$perms->write = $write;
$perms->delete = $delete;
$perms->save();
}
}
在权限模型im写入中:
use Illuminate\Database\Eloquent\SoftDeletingTrait;
class Permissions extends Eloquent {
use SoftDeletingTrait;
protected $table = 'user_permissions';
protected $fillable = ['user_id', 'model', 'read', 'write', 'delete'];
public function user()
{
return $this->belongsTo('User','user_id','id');
}
}
好的,我有从设置表单设置权限的方法。现在我需要检查用户是否具有写入或读取、删除和执行以下操作的权限:
if (Auth::user->hasRights('write', 'delete'))
//do something
请帮助我如何从DB权限中选择并使用hasRight方法检查用户权限
我认为需要检查DB的用户权限是否在数组中。这应该是什么样子
也许你能告诉我setPermission方法的小代码?谢谢你
// in User model
public function hasRights(...$accessLevels)
{
return ! $this->permissions()->filter(function (Permissions $p) use ($accessLevels) {
foreach ($accessLevels as $access) {
if ( ! $p->{$access}) return false;
}
return true;
})->isEmpty();
}