백엔드 개발 PHP 튜토리얼 Laravel 세션에 대한 혼란, 전문가가 해결할 수 있기를 바랍니다

Laravel 세션에 대한 혼란, 전문가가 해결할 수 있기를 바랍니다

Aug 26, 2016 am 10:12 AM
laravel php

laravel5.*에서는 세션 시작이

과 같은 웹 미들웨어에 배치됩니다.

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

<code>    /**

     * The application's route middleware groups.

     *

     * @var array

     */

    protected $middlewareGroups = [

        'web' => [

            \App\Http\Middleware\EncryptCookies::class,

            \Illuminate\Cookie\Middleware\AddQueuedCookiesToResponse::class,

            \Illuminate\Session\Middleware\StartSession::class,   //<---------

            \Illuminate\View\Middleware\ShareErrorsFromSession::class,

            \App\Http\Middleware\VerifyCsrfToken::class,

        ],

        'api' => [

            'throttle:60,1',

            'bindings',

        ],

    ];</code>

로그인 후 복사

그리고 Route loading 미들웨어의 코드에 따르면 컨트롤러는 미들웨어가 만들어진 후에만 호출한다는 것을 알 수 있습니다

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

<code>    /**

     * Get the middleware for the route's controller.

     *

     * @return array

     */

    public function controllerMiddleware()

    {

        if (! $this->isControllerAction()) {

            return [];

        }

 

        return ControllerDispatcher::getMiddleware(

            $this->getController(), $this->getControllerMethod()

        );

    }</code>

로그인 후 복사

이때 문제가 발생합니다. 생성자에 사용자 로그인 상태가 결정됩니다. 사용자가 이미 로그인되어 있으면 로그인된 사용자 정보가 $this->에 저장됩니다. ;login_user_info 첫 번째 컨트롤러를 만들면 세션이 아직 시작되지 않았으므로 생성자에서 로그인한 사용자의 session_id를 얻을 수 없습니다.

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

<code>/**

 * 控制层公有方法集合

 * Class BaseController

 */

abstract class BaseController extends Controller

{

 

    use AuthorizesRequests, DispatchesJobs, ValidatesRequests;

 

    public $login_user_info;

    public $login_subuser_info;

 

    public function __construct()

    {

        $this->userModel    = app(UserModel::class);

        if (session()->get('user_id')) {

            $this->login_user_info          = $this->userModel->getLoginUser();

            //设置模板全局变量

            view()->share(['login_user_info' => $this->login_user_info]);

        }

    }</code>

로그인 후 복사

이때 StartSession 미들웨어 코드가 실행되었기 때문에 미들웨어에서 세션을 얻을 수 있는지 테스트해봤습니다. 프레임워크를 laravel로 전환하므로 원래 논리를 최대한 유지하기 위해 이상한 작성 방법이 있으므로 현재로서는 Auth를 사용하지 않습니다. 생성자에서 세션을 가져올 수 있는 방법이 있습니까? 도와주세요, 감사합니다

본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

Video Face Swap

Video Face Swap

완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

인기 기사

<gum> : Bubble Gum Simulator Infinity- 로얄 키를 얻고 사용하는 방법
4 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
Nordhold : Fusion System, 설명
4 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
Mandragora : 마녀 트리의 속삭임 - Grappling Hook 잠금 해제 방법
4 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
<exp exp> 모호한 : 원정 33- 완벽한 크로마 촉매를 얻는 방법
2 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

session_start () 함수의 중요성은 무엇입니까? session_start () 함수의 중요성은 무엇입니까? May 03, 2025 am 12:18 AM

session_start () iscrucialinphpformanagingUsersessions.1) itiniteSanewsessionifnoneexists, 2) ResumesAnxistessions, and3) setSasessionCookieForContInuityAcrosrequests, enablingplicationsirecationSerauthenticationAndpersonalizestContent.

PHP 프레임 워크 Laravel과 YII의 차이점은 무엇입니까? PHP 프레임 워크 Laravel과 YII의 차이점은 무엇입니까? Apr 30, 2025 pm 02:24 PM

Laravel과 YII의 주요 차이점은 설계 개념, 기능적 특성 및 사용 시나리오입니다. 1. Laravel은 개발의 단순성과 즐거움에 중점을두고 Eloquentorm 및 Artisan 도구와 같은 풍부한 기능을 제공하며 빠른 개발 및 초보자에게 적합합니다. 2.YII는 성능과 효율성을 강조하고, 고 부하 애플리케이션에 적합하며, 효율적인 Activerecord 및 캐시 시스템을 제공하지만 가파른 학습 곡선이 있습니다.

데이터 처리 및 계산에 MySQL 기능을 사용하는 방법 데이터 처리 및 계산에 MySQL 기능을 사용하는 방법 Apr 29, 2025 pm 04:21 PM

MySQL 기능은 데이터 처리 및 계산에 사용될 수 있습니다. 1. 기본 사용에는 문자열 처리, 날짜 계산 및 수학 연산이 포함됩니다. 2. 고급 사용에는 복잡한 작업을 구현하기 위해 여러 기능을 결합하는 것이 포함됩니다. 3. 성능 최적화를 위해서는 WHERE 절에서 기능 사용 및 GroupBy 및 임시 테이블 사용을 피해야합니다.

권장 Laravel의 최고의 확장 팩 : 2024 필수 도구 권장 Laravel의 최고의 확장 팩 : 2024 필수 도구 Apr 30, 2025 pm 02:18 PM

2024 년의 필수 Laravel 확장 패키지는 다음과 같습니다. 1. Laraveldebugbar, 코드를 모니터링하고 디버그하는 데 사용됩니다. 2. 자세한 응용 프로그램 모니터링을 제공하는 Laraveltelescope; 3. Laravelhorizon, Redis 대기열 작업 관리. 이러한 확장 팩은 개발 효율성 및 응용 프로그램 성능을 향상시킬 수 있습니다.

작곡가 : PHP 개발자의 패키지 관리자 작곡가 : PHP 개발자의 패키지 관리자 May 02, 2025 am 12:23 AM

Composer는 PHP의 종속성 관리 도구이며 Composer.json 파일을 통해 프로젝트 종속성을 관리합니다. 1) 종속성 정보를 얻기 위해 Composer.json을 구문 분석합니다. 2) 종속성 트리를 형성하기위한 종속성; 3) Packagist에서 공급 업체 디렉토리로 종속성을 다운로드하여 설치합니다. 4) Composer.Lock 파일을 생성하여 팀 일관성 및 프로젝트 유지 관리 가능성을 보장하기 위해 종속성 버전을 잠그십시오.

Laravel 로그 및 오류 모니터링 : Sentry 및 Bugsnag 통합 Laravel 로그 및 오류 모니터링 : Sentry 및 Bugsnag 통합 Apr 30, 2025 pm 02:39 PM

Laravel에 Sentry와 Bugsnag를 통합하면 응용 프로그램 안정성과 성능이 향상 될 수 있습니다. 1. Composer.json에 Sentrysdk를 추가하십시오. 2. config/app.php에 센트리 서비스 제공 업체를 추가하십시오. 3. .env 파일에서 sentrydsn을 구성하십시오. 4. app \ exceptions \ handler.php에서 센트리 오류 보고서를 추가하십시오. 5. 센트리를 사용하여 예외를 잡고보고하고 추가 컨텍스트 정보를 추가하십시오. 6. app \ exceptions \ handler.php의 ugsnag 오류 보고서를 추가하십시오. 7. Bugsnag 모니터링을 사용하십시오

Laravel 라이브 채팅 응용 프로그램 : WebSocket 및 Pusher Laravel 라이브 채팅 응용 프로그램 : WebSocket 및 Pusher Apr 30, 2025 pm 02:33 PM

Laravel에서 라이브 채팅 애플리케이션을 구축하려면 WebSocket 및 Pusher를 사용해야합니다. 특정 단계에는 다음이 포함됩니다. 1) .env 파일의 푸시어 정보 구성; 2) 방송 드라이버를 Broadcasting.php 파일에 Pusher로 설정합니다. 3) 푸셔 채널을 구독하고 Laravelecho를 사용한 이벤트를 듣습니다. 4) 푸셔 API를 통해 메시지를 보내십시오. 5) 개인 채널 및 사용자 인증 구현; 6) 성능 최적화 및 디버깅을 수행하십시오.

MySQL의 문자 세트 및 Collation 규칙을 구성하는 방법 MySQL의 문자 세트 및 Collation 규칙을 구성하는 방법 Apr 29, 2025 pm 04:06 PM

MySQL에서 문자 세트 및 콜라주를 구성하는 방법은 다음과 같습니다. 1. 서버 수준에서 문자 세트 및 콜라주 설정 : setNames'Utf8 '; setcharactersetutf8; setCollation_connection = 'utf8_general_ci'; 2. 특정 문자 세트 및 콜라주를 사용하는 데이터베이스를 만듭니다. createAbaseexample_DBCHARACTERSETUTF8COLLATEUTF8_GENERAL_CI; 3. 테이블을 만들 때 문자 세트 및 콜라주를 지정하십시오 : CreateTableAmplipt_table (idint

See all articles