我正在对用户进行权限检查,以确定他们是否可以查看网页。这涉及到首先通过一些中间件传递请求。
我遇到的问题是,在将数据返回给视图本身之前,我在中间件和控制器中复制了相同的数据库查询。
下面是一个设置的例子;
路线 php
Route::get('pages/{id}', [
'as' => 'pages',
'middleware' => 'pageUser'
'uses' => 'PagesController@view'
]);
—— PageUserMiddleware.php (类 PageUserMiddleware)
public function handle($request, Closure $next)
{
//get the page
$pageId = $request->route('id');
//find the page with users
$page = Page::with('users')->where('id', $pageId)->first();
//check if the logged in user exists for the page
if(!$page->users()->wherePivot('user_id', Auth::user()->id)->exists()) {
//redirect them if they don't exist
return redirect()->route('redirectRoute');
}
return $next($request);
}
—— PagesController.php
public function view($id)
{
$page = Page::with('users')->where('id', $id)->first();
return view('pages.view', ['page' => $page]);
}
如您所见,Page::with('users')->where('id', $id)->first()
在中间件和控制器中都是重复的。我需要将数据从一个传递到另一个,这样就不会重复。