страница ошибки laravel 404, редирект - PullRequest
0 голосов
/ 03 мая 2018

в поисках помощи, я выбираю опрос и вопросы из метода, когда выбираю опрос по идентификатору, из маршрута. Но когда я удаляю опрос, и при записи в URL, например, http://localhost/survey_details/27 (27 - это идентификатор опроса, который больше не существует), я получаю не некоторую информацию, перенаправление или страницу не найдена, но появляется ошибка, при которой неопределенная переменная $ dat. Но мне нужно кое-что, как показать страницу 404 не найденной, или просто перенаправить на другую страницу, если идентификатор не существует. Кто-нибудь может мне помочь? вот мой маршрут:

Route::get('survey_draft/{id}', 'SurveyController@editSurveyDraft');

Вот мой контроллер:

public function viewSurvey($id)
{

    $object = DB::table('question')
        ->where('survey_id', '=', $id)
        ->where('name', '!=', NULL)
        ->get();

    $teamName = DB::table('survey')->where('surveyId', '=', $id)
        ->join('team', 'survey.teamId', '=', 'team.teamId')
        ->join('company', 'company.id', '=', 'team.companyID')
        ->get();

    $company = Auth::user()->company;

    $data = Survey::where('surveyId', '=', $id)->get();
    $teams = Auth::user()->teams;

    $checkUserTeam = DB::table('teammembersall')
        ->where('UserId', '=', Auth::user()->id)
        ->get();

    $members = Survey::where('surveyId', '=', $id)
        ->join('team', 'team.teamId', '=', 'survey.teamId')
        ->join('teammembersall', 'teammembersall.TeamId', '=', 'team.TeamId')
        ->join('users', 'users.id', '=', 'teammembersall.UserId')
        ->select('users.*')
        ->whereNotExists(function ($query) use ($id) {
            $query->select(DB::raw(1))
                ->from('answer')
                ->whereRaw('answer.answerAboutUserId = users.id')
                ->where('answer.surveyId', '=', $id)
                ->where('answer.member_id', '=', Auth::user()->id);
        })
        ->get();

    $questions = DB::table('answer')->get();

    return view('survey_details', ['object' => $object, 'data' => $data, 'teams' => $teams, 'members' => $members, 'questions' => $questions, 'checkUserTeam' => $checkUserTeam, 'teamName' => $teamName, 'company' => $company]);
}

1 Ответ

0 голосов
/ 03 мая 2018

Чтобы решить вашу непосредственную проблему, вы можете добавить один из них после $ object ... get () в зависимости от вашего результата. Один из них должен работать.

if(empty($object)){ abort(404); }

или

if(!$object->count()){ abort(404); }

Однако ваш код был бы намного проще, если бы вы использовали 2 базовые технологии Laravel.

  1. ORM вместо DB :: ...
  2. Привязка модели маршрута. (который будет обрабатывать ваши 404 для вас)

https://laravel.com/docs/5.6/eloquent

https://laravel.com/docs/5.6/routing#route-model-binding

...