목차
입니다.
백엔드 개발 PHP 튜토리얼 Laravel의 세션에 대한 깊은 다이빙

Laravel의 세션에 대한 깊은 다이빙

Mar 06, 2025 am 02:32 AM

A Deep Dive into Sessions in Laravel 라벨 애플리케이션을 구축 할 때는 어느 시점에서 세션을 처리해야한다고 확신합니다. 그들은 웹 개발의 기본 부분입니다.

이 기사는 세션이 무엇인지, Laravel에서 작동하는 방법 및 Laravel 애플리케이션에서 사용하는 방법을 신속하게 설명합니다.

그런 다음 한 걸음 더 나아가서 "세션 클래스"를 사용하여 세션과 상호 작용하는 방법을 다룰 것입니다.

마지막으로, 우리는 Laravel에서 세션 데이터를 테스트하는 방법을 배웁니다.

대화 란 무엇입니까?

기본적으로 웹 애플리케이션은 무국적자이며, 의미는 일반적으로 서로를 알지 못합니다. 따라서 요청간에 데이터를 저장하는 방법이 필요합니다. 예를 들어, 사용자가 웹 사이트에 로그인하면 방문 중에 로그인된다는 것을 기억해야합니다. 대화가 시작되는 곳입니다.

요컨대, 세션은 여러 요청간에 데이터를 유지하는 안전한 방법입니다.

세션 데이터는 다음 내용을 저장하는 데 사용될 수 있습니다.

사용자 인증 상태.

다른 페이지에서 임시 데이터에 액세스 할 수 있습니다.

플래시 메시지가 사용자에게 표시됩니다.

세션 데이터는 다음과 같은 다양한 위치에 저장 될 수 있습니다.

쿠키 ​​

데이터베이스 캐시 저장소 (예 : redis)

Laravel에서 세션은 어떻게 작동합니까?

    세션이 무엇인지 이해하기 위해 Laravel에서 어떻게 작동하는지 보자.
  • 다음은 Laravel 애플리케이션의 세션에서 찾을 수있는 일부 샘플 데이터입니다.
  • 각 키가 표현할 수있는 것을 분해합시다.
  • 다음 키는 Laravel 프레임 워크 자체에 의해 추가됩니다.
  • 값은 CSRF 공격을 방지하는 데 사용됩니다.
값은 이전에 요청한 URL을 저장하는 데 사용됩니다.

값은 이전 요청에 플래시 세션 데이터의 키를 저장하는 데 사용됩니다. 이 경우, 이전 요청에서
  • 값은 현재 요청에 플래시 세션 데이터의 키를 저장하는 데 사용됩니다.
  • 다음 키는 나에 의해 추가됩니다
  • 값은 사용자에게 표시 될 수있는 성공 메시지를 저장하는 데 사용됩니다.
  • 값은 사용자가보고있는 현재 팀의 ID를 저장하는 데 사용됩니다.

    기본적으로 Laravel은 다음 세션 드라이버를 지원합니다
      - 세션 데이터는 안전하고 암호화 된 쿠키에 저장됩니다.
    • cookie - 세션은 데이터베이스에 저장됩니다 (예 : MySQL, PostgreSQL, Sqlite).
    • /
    • - 세션 데이터는 이러한 빠른 캐시 스토리지에 저장됩니다. database - 세션 데이터는 AWS DynamoDB에 저장됩니다.
    • - 세션 데이터는
    • 에 저장됩니다. memcached redis - 세션 데이터는 메모리의 PHP 배열에 저장되며 지속되지 않습니다.
    • 이러한 드라이버 중 일부는 설정 요구 사항이 있습니다. 따라서 사용하기 전에 Laravel 문서를 확인하여 설정 방법을 배우십시오. dynamodb Laravel에서 세션을 사용하여
    • Laravel은 세션을 매우 간단하게 만듭니다. 문서는 세션과 잘 상호 작용하는 방법을 설명합니다. 그러나 기본 사항을 간단히 살펴 보겠습니다. file 이 예를 들어, 우리는 여러 페이지에 걸쳐 단계별 마법사를 구축한다고 가정합니다. 현재 단계와 각 단계에 입력 한 데이터를 세션에 저장합니다. 이런 식으로 사용자가 모든 단계를 완료하면 마법사 끝에서 제출 된 모든 데이터를 읽을 수 있습니다. storage/framework/sessions 예제를 간단하게하기 위해 Facade 또는 요청 클래스를 사용하여 세션 데이터에 액세스 할 수 있습니다.
    • # 세션에서 데이터를 읽으십시오 세션에서 데이터를 읽으려면 다음과 같이 array 메소드를 사용할 수 있습니다.
    • 위의 코드를 실행하면 세션에 저장된 값이 가 반환됩니다.

      이 메소드는 또한 기본값을 정의 할 수 있으며,이 값은 다음을 반환 할 수 있습니다.

      위의 코드를 실행하면 세션에 저장된 값이 가 반환됩니다. 세션에서 데이터를 읽고 동시에 삭제하려는 시간도있을 수 있습니다 (다시 액세스 할 수 없습니다). 다음과 같은 함수를 사용할 수 있습니다
      위의 코드를 실행하면 세션에 저장된 값을 키로 반환 한 다음 세션에서 삭제합니다.

      # 세션에 데이터를 쓰십시오 세션에 데이터를 작성하려면 다음과 같이

      함수를 사용할 수 있습니다.

      위의 코드를 실행하면 배열 (두 번째 매개 변수로 전달 됨)을

      키의 값으로 저장합니다.

      # 세션의 배열로 데이터를 푸시하십시오 마찬가지로, session() 메소드를 사용하여 세션의 배열로 데이터를 푸시 할 수도 있습니다. Session 키에 다음 데이터가 있다고 가정합니다

      위 코드 (<code>[ '_token' => 'bKmSfoegonZLeIe8B6TWvSm1dKwftKsvcT40xaaW' '_previous' => [ 'url' => 'https://my-app.com/users' ] '_flash' => [ 'old' => [ 'success', ], 'new' => [] ] 'success' => 'User created successfully.' 'current_team_id' => 123 ]</code>

      wizard:step_one:form_data:languages를 사용하여 세션 키를 만들고 값을 전달한 값을 포함하는 배열로 설정하십시오. push # 세션에서 데이터를 늘리고 감소시킵니다 Laravel은 또한 세션에서 값을 높이고 줄일 수있는 편리한 도우미 방법을 제공합니다. 당신은 다음과 같은 세션의 값을 늘릴 수 있습니다 :

      위의 코드를 실행하면 세션 값이 3 인 경우 이제 4로 증가합니다.

      당신은 또한 다음과 같은 세션의 값을 줄일 수 있습니다 :

      .

      값이 세션에 아직 존재하지 않으면 0으로 취급됩니다. 따라서 빈 세션 값에서

      를 호출하면 값이 1로 설정됩니다. 빈 세션 값에서

      를 호출하십시오. 값을 -1로 설정하십시오.

      두 방법 모두 숫자를 증가 시키거나 감소시킬 수 있습니다.
      <code>$currentStep = session()->get(key: 'wizard:current_step');</code>
      로그인 후 복사
      로그인 후 복사
      로그인 후 복사
      # 세션에서 데이터를 삭제합니다

      메소드를 사용하여 세션에서 데이터를 삭제할 수도 있습니다. wizard:current_step 위의 코드를 실행하면 세션에서

      키에 속하는 데이터가 삭제됩니다.

      한 번에 여러 키를 삭제하려면 키 어레이를 함수로 전달할 수 있습니다.

      또는 세션에서 모든 데이터를 삭제하려면 함수를 사용할 수 있습니다.
      <code>$currentStep = session()->get(key: 'wizard:current_step', default: 1);</code>
      로그인 후 복사
      로그인 후 복사
      # 세션에 데이터가 있는지 확인하십시오 Laravel은 또한 세션에 데이터가 있는지 확인하기 위해 편리한 도우미 기능을 제공합니다.

      increment 메소드를 사용하여 세션에 키가 있는지 여부와 그 값이 decrement : 가 아닌지 확인할 수 있습니다.

      값이 존재하고

      가 아닌 경우, 위의 코드는 를 반환합니다. 값이 이거나 키가 존재하지 않으면

      가 반환됩니다.
      <code>$currentStep = session()->pull(key: 'wizard:current_step');</code>
      로그인 후 복사
      마찬가지로, 메소드를 사용하여 세션에 키가 존재하는지 확인할 수도 있습니다 (값 값에 관계없이) :

      세션이 전혀 존재하지 않는지 확인할 수도 있습니다.

      # 플래시 데이터에 세션 때때로 세션에서 일부 데이터를 지속하려고하지만 다음 요청에 대해서만 지속됩니다. 예를 들어, 사용자가 양식을 제출 한 후 사용자에게 성공 알림을 표시 할 수 있습니다.

      이렇게하려면 forget 메소드 : 를 사용할 수 있습니다

      위의 코드를 실행하려면 다음 요청에서 디스플레이를 위해 세션 (와 같은 것을 사용)에서 값을 읽을 수 있습니다. 그런 다음 다음 요청에서 사용할 수 없도록 삭제하십시오.
      <code>session()->put(
          key: 'wizard:step_one:form_data',
          value: [
              'name' => 'Ash Allen',
              'email' => 'ash@example.com',
          ],
      );</code>
      로그인 후 복사
      때로는 일부 플래시 데이터 (이전 요청에 추가)가 있고 다음 요청에 따라 보관할 수 있습니다.

      당신은 wizard:current_step 메소드를 사용하여 모든 플래시 데이터를 새로 고칠 수 있습니다 : .

      또는 플래시 데이터를 유지하려면

      메소드를 사용할 수 있습니다.

      <code>[
        '_token' => 'bKmSfoegonZLeIe8B6TWvSm1dKwftKsvcT40xaaW'
        '_previous' => [
          'url' => 'https://my-app.com/users'
        ]
        '_flash' => [
          'old' => [
              'success',
          ],
          'new' => []
        ]
        'success' => 'User created successfully.'
        'current_team_id' => 123
      ]</code>
      로그인 후 복사
      로그인 후 복사
      로그인 후 복사
      로그인 후 복사
      로그인 후 복사
      위의 코드를 실행하면 플래시 세션 값이 유지되지만 다음 요청에 대한 다른 플래시 데이터는 삭제됩니다.

      기능, 외관 또는 요청 클래스를 도와 주시겠습니까? success error 지금까지, 우리는 예제에서

      헬퍼 함수 만 사용했습니다.

      그러나 Facade 또는 클래스를 사용하여 세션과 상호 작용할 수도 있습니다.

      어떤 방법을 사용하든이 기사의 앞부분에서 설명한 동일한 방법을 사용할 수 있습니다. 이러한 방법은 세션 데이터와 상호 작용하는 다른 방법입니다.
      외관을 사용하려면 다음과 같은 방법을 호출 할 수 있습니다.

      또는 컨트롤러 메소드에 주입 된 session() 메소드를 호출하여 세션에 액세스 할 수 있습니다. 다음 컨트롤러 방법이 있다고 가정합니다

      각 방법은 완전히 효과적이므로 귀하와 귀하의 팀을 선호하는 방법을 결정할 수 있습니다.

      한 걸음 더 나아가 IlluminateSupportFacadesSession IlluminateHttpRequest 소규모 프로젝트의 경우 앞에서 논의한 방법을 사용하여 세션과 상호 작용하는 것이 좋습니다. 그러나 Laravel 프로젝트가 커지면 오류를 일으키고 코드를 유지하기가 더 어려워 질 수있는 몇 가지 문제가 발생할 수 있습니다.

      그래서 우리는 이제 잠재적 인 함정과 피하는 방법을 다룰 것입니다.

      세션 키 내가 보는 일반적인 함정 (여러 번 경험했습니다)은 세션 키의 오타입니다.

      세션에 현재 단계를 저장한다고 가정 할 때 마법사 예제를 고수하십시오. 따라서 코드는 다음과 같이 보일 수 있습니다

      그런 다음 나중에 코드 기반의 다른 부분에서 세션에서 현재 단계를 읽을 수 있습니다. Session 내가 지금 저지른 실수를 보셨나요? 실수로

      키 대신
      <code>$currentStep = session()->get(key: 'wizard:current_step');</code>
      로그인 후 복사
      로그인 후 복사
      로그인 후 복사
      키를 읽으려고했습니다.

      이것은 간단한 예이지만 대형 코드베이스에서는 그러한 실수를 쉽게 할 수 있습니다. 이러한 명백한 실수는 찾기가 가장 어려울 수 있습니다. IlluminateHttpRequest 따라서 이러한 오타를 피하는 유용한 방법은 상수 또는 방법을 사용하여 세션 키를 생성하는 것입니다. session 예를 들어, 세션 키가 정적 인 경우 다음과 같이 상수를 정의 할 수 있습니다 (아마도 나중에 다룰 세션 클래스).

      이는 코드베이스에 사용되는 원시 문자열의 수를 줄여서 오타 수를 줄이는 데 도움이됩니다.
      <code>$currentStep = session()->get(key: 'wizard:current_step', default: 1);</code>
      로그인 후 복사
      로그인 후 복사
      그러나 때로는 세션 키를 동적으로 생성해야 할 수도 있습니다. 예를 들어,

      키가 팀 ID 필드를 포함하기를 원한다고 가정 해 봅시다. 다음과 같이 키를 생성하는 메소드를 만들 수 있습니다.

      위 코드에서 볼 수 있듯이 세션 키를 동적으로 생성하여 다른 방법으로 사용할 수 있습니다. 예를 들어, ID 1이있는 팀의 현재 단계를 찾으려고하면 키는

      입니다.

      # 세션 키 충돌 또 다른 함정은 한동안 주변에 있던 프로젝트를 다룰 때 보는 또 다른 함정은 세션 키 충돌입니다.

      예를 들어, 몇 년 전 새로운 사용자 계정을 만들기위한 마법사를 만들었다고 상상해보십시오. 따라서 다음과 같은 세션 데이터를 저장할 수 있습니다

      당신은 이제 마법사가있는 새로운 기능을 구축하도록 할당되었으며, 오래된 마법사와 사용한 이름 지정 컨벤션을 완전히 잊어 버렸습니다. 실수로 새 마법사에 동일한 키를 사용하여 데이터 충돌을 일으키고 잠재적 오류가 발생할 수 있습니다.

      이를 피하기 위해 함수 이름을 세션 키의 접두사로 사용하고 싶습니다. 따라서 새로운 사용자를 생성하기위한 마법사 데이터를 저장하려면 다음 키가있을 수 있습니다.

      <code>[
        '_token' => 'bKmSfoegonZLeIe8B6TWvSm1dKwftKsvcT40xaaW'
        '_previous' => [
          'url' => 'https://my-app.com/users'
        ]
        '_flash' => [
          'old' => [
              'success',
          ],
          'new' => []
        ]
        'success' => 'User created successfully.'
        'current_team_id' => 123
      ]</code>
      로그인 후 복사
      로그인 후 복사
      로그인 후 복사
      로그인 후 복사
      로그인 후 복사

      잠깐만 ...
        그러면 새 팀을 만들기 위해 새 마법사에서 다음 키가있을 수 있습니다.
      • new_user_wizard:current_step
      • new_user_wizard:step_one:form_data
      • new_user_wizard:step_two:form_data 잠깐만 ...
      • 우리는이 기사의 후반부 에이 접두사를 세션 클래스에 추가하는 방법을 설명합니다.
      • # 알 수없는 데이터 유형 이 세션 값에 데이터 유형이 무엇인지 알려주시겠습니까?
      만약 당신이 그것을 추측한다면

      의 인스턴스라고 생각한다면, 당신은 옳습니다.

      그냥 이야기하고 말하면, 세션에서 데이터를 읽을 때 어떤 유형의 데이터를 사용하고 있는지 항상 즉시 명확하지는 않습니다. 결국 데이터를 세션에 작성하는 코드를 살펴보고 그것이 무엇인지 알아 내야합니다. 이것은 산만하고 시간이 많이 걸릴 수 있으며 오류로 이어질 수 있습니다.
        세션 데이터를 읽는 코드에 주석 또는 문서 블록을 추가 할 수 있습니다. 그러나 이것은 단지 힌트입니다. 주석을 최신 상태로 유지하지 않으면 (세션 데이터 유형이 변경되는 경우) 도움이되지 않으며 오류 가능성을 높입니다.
      • 내가 사용하고 싶은 또 다른 방법은 메소드 내부의 세션 데이터를 읽고 메소드에 리턴 유형을 추가하는 것입니다. 이렇게하면 사용중인 데이터 유형이 올바른지 확인할 수 있습니다. 또한 귀하의 IDE와 코드를 읽는 사람들에게 도움이됩니다. new_team_wizard:current_step 예를 들어 이 코드를 살펴 보겠습니다
      • 이제 메소드가 a
      • 인스턴스를 반환한다는 것을 알 수 있습니다. 이것은 우리가 사용하는 데이터 유형을 명확하게 보여줍니다. 그런 다음 컨트롤러 에서이 메소드를 다음과 같이 호출 할 수 있습니다. new_team_wizard:step_one:form_data 세션 클래스의 # 프로세스 세션 데이터 이전 섹션에서 볼 수 있듯이 Laravel에서 세션을 사용할 때 몇 가지 쉬운 (그러나 일반적인) 함정이 있습니다.
      • "세션 클래스"를 사용함으로써 이러한 트랩 각각을 피할 수 있습니다 (또는 적어도 감소). 세션 클래스를 사용하여 한 곳에서 단일 기능과 관련된 세션 데이터 처리 로직을 캡슐화하고 싶습니다.
      • 예를 들어 우리는 사용자를 창출하기위한 마법사와 팀을 만들기위한 마법사가 있다고 가정 해 봅시다. 이 마법사들 각각에 대한 세션 클래스를 만들 것입니다 :

        • AppSessionsUsersNewUserWizardSession
        • 세션 클래스를 사용하면 다음을 수행 할 수 있습니다 AppSessionsTeamsNewTeamWizardSession 함수 이름을 모든 키의 접두사로 자동으로 사용하십시오.
        • 메소드에 유형 프롬프트와 리턴 유형을 추가하십시오.
        코드베이스에 사용 된 원래 문자열 수를 줄입니다.

        리팩토링 세션 데이터 구조를보다 쉽게 ​​만듭니다.

        테스트 세션 데이터를 더 쉽게 만듭니다.
          주어진 함수에 대한 세션 데이터에 대한 변경이 필요한 경우 어디로 가야하는지 정확히 알고 있습니다.
        • 세션 데이터를 처리 할 때이 클래스 기반 접근 방식을 사용하면 대규모 Laravel 프로젝트를 수행 할 때 수많은 시간이 절약됩니다. 이것은 큰 영향을 줄 수있는 간단한 방법입니다.
        • 이전 예에서는 이미 세션 클래스를 사용하는 것을 제안했습니다. 그러나이 수업을 어떻게 구축하는지 더 자세히 살펴 보겠습니다.
        • 새로운 사용자 마법사에 대한 다음 세션 클래스가 있다고 가정합니다. 언뜻보기에는 약간 압도적 일지 모르지만 코드를 살펴보고 분해합시다.
        • 위의 클래스에서 먼저 인스턴스를 수용하는 생성자를 정의합니다. 이를 통해 Laravel은 서비스 컨테이너에서
        • 클래스를 구문 분석 할 때 세션 인스턴스를 자동으로 주입합니다. 나중에 컨트롤러 에서이 작업을 수행하는 방법을 보여 드리겠습니다.
        • 그런 다음 5 개의 기본 공개 방법을 정의합니다
        • - 마법사의 현재 단계로 돌아갑니다. 설정 단계가 없으면 기본값은 입니다.
        • - 설정 마법사의 현재 단계.
        - 마법사의 주어진 단계에 대한 양식 데이터를 설정하십시오. 이 메소드는 단계 번호와

        예제를 취합니다.

        - 마법사의 주어진 단계에 대한 양식 데이터를 가져옵니다. 이 메소드는 단계 번호를 사용하여 인스턴스를 반환하거나 데이터가 존재하지 않는 경우를 반환합니다.

        - 세션에서 마법사와 관련된 모든 데이터를 삭제합니다. 마법사가 완료되거나 취소 된 경우이 방법을 호출 할 수 있습니다.

        <code>[
          '_token' => 'bKmSfoegonZLeIe8B6TWvSm1dKwftKsvcT40xaaW'
          '_previous' => [
            'url' => 'https://my-app.com/users'
          ]
          '_flash' => [
            'old' => [
                'success',
            ],
            'new' => []
          ]
          'success' => 'User created successfully.'
          'current_team_id' => 123
        ]</code>
        로그인 후 복사
        로그인 후 복사
        로그인 후 복사
        로그인 후 복사
        로그인 후 복사
        메소드 내에서 모든 키가 생성된다는 것을 알 수 있습니다. 나는 사용 된 원시 문자열의 수를 줄이기 위해이 작업을 수행하고 (오타의 가능성을 줄입니다). 이것은 또한 특정 키에 액세스하기 위해 다른 방법을 추가하려면 매우 쉽게 수행 할 수 있음을 의미합니다.

        이러한 주요 생성 방법을 사용하면 추가 이점은 갈등을 피하기 위해 키를 쉽게 접두사 할 수 있다는 것입니다. 이 예에서는 메소드를 사용하여 모든 키의 접두사를 AppSessionsUsersWizardSession로 설정했습니다. IlluminateContractsSessionSession 이제이 클래스가 설정되었으므로 컨트롤러에서 우리가 어떻게 상호 작용하는지 보자.

        위의 예에서 볼 수 있듯이

        클래스를 컨트롤러 메소드에 주입합니다. Laravel은 우리를 위해 세션 인스턴스를 자동으로 구문 분석합니다.
        <code>[
          '_token' => 'bKmSfoegonZLeIe8B6TWvSm1dKwftKsvcT40xaaW'
          '_previous' => [
            'url' => 'https://my-app.com/users'
          ]
          '_flash' => [
            'old' => [
                'success',
            ],
            'new' => []
          ]
          'success' => 'User created successfully.'
          'current_team_id' => 123
        ]</code>
        로그인 후 복사
        로그인 후 복사
        로그인 후 복사
        로그인 후 복사
        로그인 후 복사
        그런 다음 다른 클래스와 마찬가지로 상호 작용할 수 있습니다.

        처음에는 초과 교환처럼 느껴질 수 있으며 더 많은 코드 유지 보수가 필요합니다. 그러나 프로젝트가 커지면 유형의 프롬프트, 반환 유형, 주요 생성 방법 및 명명 방법 (작업을보다 설명 적으로 만드는 것)이 매우 유용합니다. AppSessionsUsersWizardSession Laravel의 테스트 세션

        코드 기반의 다른 부분과 마찬가지로 올바른 필드를 읽고 쓰여지는지 확인하기 위해 세션 데이터를 보장해야합니다.

        세션 클래스 사용의 가장 큰 이점 중 하나는 클래스의 각 방법에 대해 중앙 집중식 단위 스타일 테스트를 쉽게 작성할 수 있다는 것입니다.

        예를 들어 클래스의

        메소드에 대한 테스트를 쓸 수 있습니다. 알림으로, 다음은 다음과 같습니다

        우리는 여기에서 몇 가지 시나리오를 테스트 할 수 있습니다 :

        단계에 대한

        객체를 반환합니다.
        단계에 양식 데이터가없는 경우 를 반환하십시오.

        테스트 클래스는 다음과 같이 보일 수 있습니다

        위의 테스트 클래스에는 앞에서 언급 한 두 가지 사례를 다루는 두 가지 테스트가 있습니다.

        이 단위 스타일 테스트는 세션 클래스가 세션 데이터를 읽고 쓰도록 올바르게 구성되도록하기 위해 이상적입니다. 그러나 그들은 반드시 코드 기반의 나머지 부분에서 올바르게 사용된다고 믿게 만드는 것은 아닙니다. 예를 들어, AppSessionsUsersWizardSession를 호출 할 수 있으며 getFormDataForStep로 전화해야합니다.

        이러한 이유로 기능 테스트 (일반적으로 컨트롤러에 쓰는 것)에서 세션 데이터를 주장하는 것을 고려할 수도 있습니다.
        <code>$currentStep = session()->get(key: 'wizard:current_step');</code>
        로그인 후 복사
        로그인 후 복사
        로그인 후 복사
        예를 들어 컨트롤러에 다음과 같은 기본 메소드가 있다고 가정하고 마법사의 다음 단계로 이동한다고 가정합니다.

        위의 방법에서는 먼저 세션에서 현재 단계를 읽습니다. 그런 다음 세션의 현재 단계에 대한 양식 데이터를 저장합니다. 마지막으로 현재 단계를 증가시키고 마법사의 다음 단계로 리디렉션합니다.

        우리는 클래스가 양식 데이터를 검증 할 책임이 있다고 가정하고 메소드를 호출 할 때
          인스턴스를 반환합니다.
        • 우리는 또한 AppDataTransferObjectsWizardsUsersFormData 컨트롤러 메소드가 경로 ()에 대한 사후 요청을 통해 액세스 할 수 있다고 가정합니다.
        • 우리는 양식 데이터가 세션에 올바르게 저장되도록하기 위해 다음 테스트를 작성할 수 있습니다.
          <code>[
            '_token' => 'bKmSfoegonZLeIe8B6TWvSm1dKwftKsvcT40xaaW'
            '_previous' => [
              'url' => 'https://my-app.com/users'
            ]
            '_flash' => [
              'old' => [
                  'success',
              ],
              'new' => []
            ]
            'success' => 'User created successfully.'
            'current_team_id' => 123
          ]</code>
          로그인 후 복사
          로그인 후 복사
          로그인 후 복사
          로그인 후 복사
          로그인 후 복사
          위의 테스트에서는 일부 양식 데이터를 사용하여 경로에 대한 게시물 요청을 발행합니다.

          를 사용하고 있음을 알 수 있습니다. 이 방법을 사용하면 세션 데이터를 설정하여 올바르게 읽을 수 있다고 주장 할 수 있습니다. /users/wizard/next-step 그런 다음 사용자가 마법사의 다음 단계로 리디렉션되고 세션의 현재 단계가 withSession로 설정되었다고 주장합니다. 또한 에 대한 양식 데이터가 세션에 올바르게 저장되어 있다고 주장합니다.

          테스트에서 보았 듯이 세션에서 두 가지 방법으로 읽습니다. 3 2 메소드를 사용하여 세션 데이터가 올바르게 설정되어 있는지 확인하십시오.

          헬퍼 함수를 ​​사용하여 세션 데이터를 직접 읽으십시오.

            두 가지 방법 모두 작동하므로 선호하는 방법을 결정할 수 있습니다. 위 테스트에서 두 가지 방법을 모두 사용하여 여러 옵션이 있음을 보여줍니다.
          • assertSessionHas 결론
          • 이 기사가 세션이 무엇인지, Laravel에서의 작동 방식을 잘 이해하는 데 도움이되기를 바랍니다. 또한 일반적인 함정을 피하기 위해 클래스 기반 방법을 사용하여 세션 데이터와 상호 작용하는 방법에 대한 아이디어를 제공하기를 바랍니다.

    위 내용은 Laravel의 세션에 대한 깊은 다이빙의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

    본 웹사이트의 성명
    본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 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 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

    뜨거운 도구

    메모장++7.3.1

    메모장++7.3.1

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

    SublimeText3 중국어 버전

    SublimeText3 중국어 버전

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

    스튜디오 13.0.1 보내기

    스튜디오 13.0.1 보내기

    강력한 PHP 통합 개발 환경

    드림위버 CS6

    드림위버 CS6

    시각적 웹 개발 도구

    SublimeText3 Mac 버전

    SublimeText3 Mac 버전

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

    PHP의 다른 오류 유형을 설명하십시오 (통지, 경고, 치명적인 오류, 구문 분석 오류). PHP의 다른 오류 유형을 설명하십시오 (통지, 경고, 치명적인 오류, 구문 분석 오류). Apr 08, 2025 am 12:03 AM

    PHP에는 4 가지 주요 오류 유형이 있습니다. 1. NOTICE : 가장 작은 것은 정의되지 않은 변수에 액세스하는 것과 같이 프로그램을 방해하지 않습니다. 2. 경고 : 심각한 통지는 파일을 포함하지 않는 것과 같은 프로그램을 종료하지 않습니다. 3. FatalError : 가장 심각한 것은 기능을 부르는 것과 같은 프로그램을 종료합니다. 4. parseerror : 구문 오류는 엔드 태그를 추가하는 것을 잊어 버리는 것과 같이 프로그램이 실행되는 것을 방지합니다.

    PHP 및 Python : 두 가지 인기있는 프로그래밍 언어를 비교합니다 PHP 및 Python : 두 가지 인기있는 프로그래밍 언어를 비교합니다 Apr 14, 2025 am 12:13 AM

    PHP와 Python은 각각 고유 한 장점이 있으며 프로젝트 요구 사항에 따라 선택합니다. 1.PHP는 웹 개발, 특히 웹 사이트의 빠른 개발 및 유지 보수에 적합합니다. 2. Python은 간결한 구문을 가진 데이터 과학, 기계 학습 및 인공 지능에 적합하며 초보자에게 적합합니다.

    PHP에서 보안 비밀번호 해싱을 설명하십시오 (예 : Password_hash, Password_Verify). 왜 MD5 또는 SHA1을 사용하지 않습니까? PHP에서 보안 비밀번호 해싱을 설명하십시오 (예 : Password_hash, Password_Verify). 왜 MD5 또는 SHA1을 사용하지 않습니까? Apr 17, 2025 am 12:06 AM

    PHP에서 Password_hash 및 Password_Verify 기능을 사용하여 보안 비밀번호 해싱을 구현해야하며 MD5 또는 SHA1을 사용해서는 안됩니다. 1) Password_hash는 보안을 향상시키기 위해 소금 값이 포함 된 해시를 생성합니다. 2) Password_verify 암호를 확인하고 해시 값을 비교하여 보안을 보장합니다. 3) MD5 및 SHA1은 취약하고 소금 값이 부족하며 현대 암호 보안에는 적합하지 않습니다.

    PHP 실행 : 실제 예제 및 응용 프로그램 PHP 실행 : 실제 예제 및 응용 프로그램 Apr 14, 2025 am 12:19 AM

    PHP는 전자 상거래, 컨텐츠 관리 시스템 및 API 개발에 널리 사용됩니다. 1) 전자 상거래 : 쇼핑 카트 기능 및 지불 처리에 사용됩니다. 2) 컨텐츠 관리 시스템 : 동적 컨텐츠 생성 및 사용자 관리에 사용됩니다. 3) API 개발 : 편안한 API 개발 및 API 보안에 사용됩니다. 성능 최적화 및 모범 사례를 통해 PHP 애플리케이션의 효율성과 유지 보수 성이 향상됩니다.

    HTTP 요청 방법 (Get, Post, Put, Delete 등)이란 무엇이며 언제 각각을 사용해야합니까? HTTP 요청 방법 (Get, Post, Put, Delete 등)이란 무엇이며 언제 각각을 사용해야합니까? Apr 09, 2025 am 12:09 AM

    HTTP 요청 방법에는 각각 리소스를 확보, 제출, 업데이트 및 삭제하는 데 사용되는 Get, Post, Put and Delete가 포함됩니다. 1. GET 방법은 리소스를 얻는 데 사용되며 읽기 작업에 적합합니다. 2. 게시물은 데이터를 제출하는 데 사용되며 종종 새로운 리소스를 만드는 데 사용됩니다. 3. PUT 방법은 리소스를 업데이트하는 데 사용되며 완전한 업데이트에 적합합니다. 4. 삭제 방법은 자원을 삭제하는 데 사용되며 삭제 작업에 적합합니다.

    PHP : 웹 개발의 핵심 언어 PHP : 웹 개발의 핵심 언어 Apr 13, 2025 am 12:08 AM

    PHP는 서버 측에서 널리 사용되는 스크립팅 언어이며 특히 웹 개발에 적합합니다. 1.PHP는 HTML을 포함하고 HTTP 요청 및 응답을 처리 할 수 ​​있으며 다양한 데이터베이스를 지원할 수 있습니다. 2.PHP는 강력한 커뮤니티 지원 및 오픈 소스 리소스를 통해 동적 웹 컨텐츠, 프로세스 양식 데이터, 액세스 데이터베이스 등을 생성하는 데 사용됩니다. 3. PHP는 해석 된 언어이며, 실행 프로세스에는 어휘 분석, 문법 분석, 편집 및 실행이 포함됩니다. 4. PHP는 사용자 등록 시스템과 같은 고급 응용 프로그램을 위해 MySQL과 결합 할 수 있습니다. 5. PHP를 디버깅 할 때 error_reporting () 및 var_dump ()와 같은 함수를 사용할 수 있습니다. 6. 캐싱 메커니즘을 사용하여 PHP 코드를 최적화하고 데이터베이스 쿼리를 최적화하며 내장 기능을 사용하십시오. 7

    PHP는 파일 업로드를 어떻게 단단히 처리합니까? PHP는 파일 업로드를 어떻게 단단히 처리합니까? Apr 10, 2025 am 09:37 AM

    PHP는 $ \ _ 파일 변수를 통해 파일 업로드를 처리합니다. 보안을 보장하는 방법에는 다음이 포함됩니다. 1. 오류 확인 확인, 2. 파일 유형 및 크기 확인, 3 파일 덮어 쓰기 방지, 4. 파일을 영구 저장소 위치로 이동하십시오.

    self ::, parent ::, 그리고 static :: php oop의 차이점을 설명하십시오. self ::, parent ::, 그리고 static :: php oop의 차이점을 설명하십시오. Apr 09, 2025 am 12:04 AM

    phpoop에서 self ::는 현재 클래스를 말하며, Parent ::는 부모 클래스를 말하며, static ::는 늦은 static 바인딩에 사용됩니다. 1. self :: 정적 방법과 일정한 호출에 사용되지만 늦은 정적 바인딩을 지원하지는 않습니다. 2.parent :: 하위 클래스가 상위 클래스 방법을 호출하는 데 사용되며 개인 방법에 액세스 할 수 없습니다. 3. Static ::는 상속 및 다형성에 적합한 후기 정적 결합을 지원하지만 코드의 가독성에 영향을 줄 수 있습니다.

    See all articles