我正在创建一个逻辑,其中一个控制器可以调用另一个控制器取决于Auth :: user()角色,但并非所有控制器都共享相同的方法,因此我想如果控制器调用不存在的方法,它将抛出一个逻辑。找不到404。 这是我的控制器
class LokalController extends Controller
{
/**
* Display a listing of the resource.
*
* @return \Illuminate\Http\Response
*/
Public $controller;
public function __construct()
{
//$this->middleware('adminakses');
$this->middleware(function ($request, $next) {
$this->setController();
return $next($request);
});
}
public function setController()
{
$role = Auth::user()->role;
switch ($role)
{
case 'admin':
$this->controller = new \SIA\Http\Controllers\Admin\LokalController;
break;
case 'guru':
$this->controller = new \SIA\Http\Controllers\Guru\LokalController;
break;
case 'siswa':
$this->controller = new \SIA\Http\Controllers\Guru\LokalController;
break;
}
}
public function index()
{
return $this->controller->index();
}
例如Admin \ LokalController具有方法A(),但Guru \ LokalController没有,并且,如果用户以guru登录并尝试校准方法A(),则它应返回未找到的异常或用户可理解的消息,但是当前显示BadMethodCallException方法A()不存在
答案 0 :(得分:0)
您正在尝试的方法是可以实现的,但我认为它会在时间上淹没您。
public function index()
{
try {
$action = $this->controller . '@' . __FUNCTION__;
action($action);
} catch (Exception $e) {
abort('401', "Your Message");
}
}
相反,我将为用户模型创建重定向路径。
public function getRedirectPathAttribute() {
switch ($this->role) {
case 'admin':
return '/admin';
case 'guru':
return '/guru';
case 'siswa':
return '/siswa';
}
}
然后创建一个中间件进行检查,如果需要重定向,我将使用auth()->user()->redirect_path
进行重定向。
你怎么看?
答案 1 :(得分:0)
一个选择是让一个控制器通过调用App :: abort(404)从所有该控制器继承来实现所有方法,并且在每个子类中实现他们所需的方法,并停止父类中的方法被称为
class BaseController extends Controller{
public function a() {
App::abort(404);
}
}
class AdminController extends BaseController{
public function a() {
// to stuff for admin
}
}
从BaseController继承的未实现a()的控制器将获得404,而管理控制器则不会得到