라벨 애플리케이션을 구축 할 때는 어느 시점에서 세션을 처리해야한다고 확신합니다. 그들은 웹 개발의 기본 부분입니다.
이 기사는 세션이 무엇인지, 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 중국어 웹사이트의 기타 관련 기사를 참조하세요!