세션 관리

세션 관리는 API 보안을 위한 DoS(서비스 거부 방지) 모범 사례입니다. 세션은 방문자가 사이트에서 보낸 시간을 나타내며 관리자 또는 고객이 계정에 로그인한 시간과 관련이 없습니다.

세션은 동일한 사용자와 연관된 네트워크 HTTP 요청 및 응답 트랜잭션의 시퀀스입니다. 이는 클라이언트(관리자)가 서버에 액세스할 때 해당 데이터와 연결하는 방법입니다. 세션은 액세스 권한 및 현지화 설정과 같은 변수를 설정하는 데 사용됩니다. 이러한 변수는 세션 중에 사용자가 웹 애플리케이션과 갖는 모든 상호 작용에 적용됩니다.

세션 크기

다음 구성 설정을 사용하여 관리자 사용자 및 상점 방문자의 최대 세션 크기를 제한하십시오.

  • Max Session Size in Admin—최대 세션 크기를 바이트 단위로 제한합니다. 0을(를) 사용하여 비활성화하십시오.
  • Max Session Size in Storefront—최대 세션 크기를 바이트 단위로 제한합니다. 0을(를) 사용하여 비활성화하십시오.
TIP
두 설정 모두 바이트 단위로 측정되며 기본값은 256000바이트(또는 256KB)입니다.

최대 세션 크기를 구성하려면:

  1. 관리자 사이드바에서 Stores > Settings>Configuration(으)로 이동합니다.

  2. 왼쪽 패널에서 Advanced ​을(를) 확장하고 System ​을(를) 선택합니다.

  3. Security 섹션에서 확장 선택기 를 확장하여 세션 설정에 액세스합니다.

    세션 설정 {width="600" modal="regular"}

  4. 새 세션 크기를 바이트 단위로 입력하십시오.

    note warning
    WARNING
    값을 너무 낮게 설정하면 문제가 발생할 수 있습니다. 기본값(256000바이트) 아래에 있는 옵션 중 하나를 설정하면 경고 메시지가 표시됩니다. No ​을(를) 클릭하면 값이 256000(으)로 변경됩니다.
  5. Save Config ​을(를) 클릭합니다.

관리 세션

최대 세션 크기를 초과하면 오류 메시지가 표시되고 시스템이 세션 크기 제한을 var/log 디렉터리에 기록합니다.

세션 크기를 너무 낮게 설정한 후 관리자에 대한 액세스 권한을 잃을 경우 CLI를 사용하여 구성을 재설정하십시오.

bin/magento config:set system/security/max_session_size_admin 256000

Storefront 세션

최대 세션 크기를 초과하면 오류가 표시되지 않지만 시스템은 세션 크기 제한을 var/log 디렉터리에 기록합니다.

세션 유효성 검사

Adobe Commerce 및 Magento Open Source을 사용하면 가능한 세션 고정 공격이나 사용자 세션을 포이즌 또는 납치하려는 시도에 대한 보호 조치로 세션 변수의 유효성을 확인할 수 있습니다. 세션 유효성 검사 설정은 각 저장소 방문 동안 세션 변수의 유효성 검사 방법과 세션 ID가 저장소의 URL에 포함되어 있는지 여부를 결정합니다.

자세한 내용은 구성 가이드 ​에서 세션 저장소에 Redis 사용을 참조하십시오.

일반 구성 - 웹 세션 유효성 검사

유효성 검사는 사용자에 대해 $_SESSION 데이터에 저장된 세션 데이터와 유효성 검사 변수의 값을 비교하여 방문자가 자신이 말한 사람인지 확인합니다. 정보가 예상대로 전송되지 않고 해당 변수가 비어 있으면 유효성 검사가 실패합니다. 세션 유효성 검사 설정에 따라 세션 변수가 유효성 검사 프로세스에 실패하면 클라이언트 세션이 즉시 종료됩니다.

모든 유효성 검사 변수를 활성화하면 공격을 방지하는 데 도움이 될 수 있지만, 서버 성능에도 영향을 줄 수 있습니다. 기본적으로 모든 세션 변수 유효성 검사는 비활성화되어 있습니다. 설정을 실험하여 Adobe Commerce 또는 Magento Open Source 설치에 가장 적합한 조합을 찾는 것이 좋습니다. 모든 유효성 검사 변수를 활성화하면 너무 제한적일 수 있으며, 프록시 서버를 통하거나 방화벽 뒤에서 시작되는 인터넷 연결을 사용하는 고객에 대한 액세스가 차단될 수 있습니다. 세션 변수 및 그 사용에 대한 자세한 내용은 Linux® 시스템의 시스템 관리 설명서를 참조하십시오.

세션 유효성 검사를 구성하려면:

  1. 관리자 사이드바에서 Stores > Settings>Configuration(으)로 이동합니다.

  2. 왼쪽 패널에서 General ​을(를) 확장하고​ Web ​을(를) 선택합니다.

  3. Session Validation Settings 섹션에서 확장 선택기 를 확장합니다.

  4. 각 구성 옵션을 설정합니다.

    • Validate REMOTE_ADDR — 요청의 IP 주소가 $_SESSION 변수에 저장된 주소와 일치하는지 확인하려면 Yes(으)로 설정합니다.

    • Validate HTTP_VIAYes(으)로 설정하여 들어오는 요청의 프록시 주소가 $_SESSION 변수에 저장된 주소와 일치하는지 확인합니다.

    • Validate HTTP_X_FORWARDED_FOR — 요청의 forwarded-for 주소가 $_SESSION 변수에 저장된 주소와 일치하는지 확인하려면 Yes(으)로 설정합니다.

    • Validate HTTP_USER_AGENT — 세션 중에 저장소에 액세스하는 데 사용되는 브라우저나 장치가 $_SESSION 변수에 저장된 항목과 일치하는지 확인하려면 Yes(으)로 설정합니다.

  5. 완료되면 Save Config ​을(를) 클릭합니다.

관리 세션 수명

보안 조치로서 관리자 ​는 처음에는 키보드 비활동이 900초(15분) 후에 시간 초과로 설정됩니다. 작업 스타일에 맞게 세션 수명을 조정할 수 있습니다.

관리자 세션 수명을 조정하려면:

  1. 관리자 사이드바에서 Stores > Settings>Configuration(으)로 이동합니다.

  2. 아래로 스크롤하여 왼쪽 패널에서 Advanced ​을(를) 확장합니다.

  3. Admin ​을(를) 클릭합니다.

  4. Security ​섹션에서 확장 선택기 를 확장합니다.

  5. Admin Session Lifetime (seconds) ​에 시간이 초과되기 전에 세션이 활성 상태로 유지되는 시간(초)을 입력합니다.

    고급 구성 - 관리자 보안 설정 {width="600" modal="regular"}

  6. 완료되면 Save Config ​을(를) 클릭합니다.## 관리자 세션 수명

보안 조치로서 관리자 ​는 처음에는 키보드 비활동이 900초(15분) 후에 시간 초과로 설정됩니다. 작업 스타일에 맞게 세션 수명을 조정할 수 있습니다.

관리자 세션 수명을 조정하려면:

  1. 관리자 사이드바에서 Stores > Settings>Configuration(으)로 이동합니다.

  2. 아래로 스크롤하여 왼쪽 패널에서 Advanced ​을(를) 확장합니다.

  3. Admin ​을(를) 클릭합니다.

  4. 보안 섹션에서 확장 선택기 를 확장합니다.

  5. Admin Session Lifetime (seconds) ​에 시간이 초과되기 전에 세션이 활성 상태로 유지되는 시간(초)을 입력합니다.

    고급 구성 - 관리자 보안 설정 {width="600" modal="regular"}

  6. 완료되면 Save Config ​을(를) 클릭합니다.

recommendation-more-help
d3c62084-5181-43fb-bba6-1feb2fcc3ec1