피드백 질문

미들웨어에서 auth()->check() 관련 질문

App\Http\Kernel.php

...

protected $middlewareGroups = [

    'web' => [

        \App\Alrimi::class,

        ...

    ]

    ...

]

 

App\alrimi.php

....

public function handle($request, Clouser $next)

{

    // 변수 설정
        $alrimLink = array();
        $alrimContent = array();
        if (auth()->check()) {
            $results = DB::select('SELECT * FROM laon_alrimi WHERE users_id = (?) AND read_at = 0', array(auth()->user()->email));
            foreach ($results as $result) {
                $alrimLink[] = $result->link;
                $alrimContent[] = $result->content;
            }
            $compact = compact(
                'alrimLink', 'alrimContent'
            );

            view()->share($compact);
        } else {
            $alrimLink = "A";
            $alrimContent = "B";
            $compact = compact(
                'alrimLink', 'alrimContent'
            );

            view()->share($compact);
        }
        return $next($request);

}

 

resource\views\layout\basic.blade.php

{{ $alrimLink }}

...

 

라온보드 게시판과, MPUG 단톡방, 다른 미들웨어 소스를 참고하며 테스트 코드를 만들어보았습니다.

근데 로그인을 하든, 회원가입을 하든, A만 출력이 됩니다.

미들웨어에서 로그인 여부를 파악할려면 auth()->check()라고 게시판에서 보았고 또 다른 미들웨어에서도 저런 식으로 사용하는데 이 문제는 윈도우 환경이라서 그런걸까요 아님, 다른 문제가 있어서 그럴까요.

 

 

 

추천 0 비추천 0

댓글 2개

Kernel.php 의 미들웨어 그룹 배열의 web 항목에 보시면

// 설치가 되었는지 검사
\App\Http\Middleware\CheckInstall::class,
\App\Http\Middleware\EncryptCookies::class,
\Illuminate\Cookie\Middleware\AddQueuedCookiesToResponse::class,
\Illuminate\Session\Middleware\StartSession::class,
// \Illuminate\Session\Middleware\AuthenticateSession::class,
\Illuminate\View\Middleware\ShareErrorsFromSession::class,
\App\Http\Middleware\VerifyCsrfToken::class,
\Illuminate\Routing\Middleware\SubstituteBindings::class,
// 설정 등록
\App\Http\Middleware\ConfigRegister::class,

이런식으로 되어 있을겁니다.
\App\Alrimi::class, 이 클래스를 \Illuminate\Session\Middleware\StartSession::class,
다음에 실행하게 하셔야 의도한대로 동작할 것입니다. StratSession 다음에 어디에 두셔도 상관없습니다.

로그인이라는게 세션에 로그인 정보를 담는 작업이니
라라벨 세션을 시작시켜줘야 auth()->check() 가 제대로 동작하는 걸로 생각되네요.
전체 86건 5페이지
번호 제목 글쓴이 날짜 조회 추천 비추천
46 버그제보

글이 지워졌을 때..

1
마젠토 10/03 4644 0 0
45 버그제보

게시판글 안에 그림이 있는 것을 Copy & Paste 했을 때..

1
마젠토 10/03 5622 0 0
44 버그제보

최근 게시물 스킨...

1
마젠토 10/02 5450 0 0
43 버그제보

관리자모드에서 회원추가시....

2
아파치 09/30 5967 0 0
42 제안

routes.php의 Contents/{id} 에서..

1
마젠토 09/30 3509 0 0
41 버그제보

댓글을 관리자가 지우려고 할때..

1
마젠토 09/30 3867 0 0
40 제안

카테고리 게시글이 있을 경우에..

1
마젠토 09/30 4012 0 0
39 버그제보

로그인을 한후에 게시글에 답변을 할 경우에..

1
마젠토 09/30 4275 0 0
38 버그제보

Re: 로그인을 한후에 게시글에 답변을 할 경우에..

1
마젠토 09/30 2613 0 0
37 질문

0.98 패치후....

2
아파치 09/28 4209 0 0