Docs Menu

사용자 세션 관리

App Services는 액세스 토큰 및 새로 고침 토큰을 사용하여 사용자 세션을 관리합니다. 액세스 토큰을 사용하면 해당 토큰이 있는 사람은 누구나 최대 30분 동안 연결된 세션을 사용할 수 있습니다. 새로 고침 토큰을 사용하면 이전 토큰이 이미 만료된 경우에도 세션에 대한 새 액세스 토큰을 생성할 수 있습니다.

Realm SDK는 사용자가 App Services에 접속할 때 자동으로 사용자 액세스와 새로 고침 토큰을 관리합니다. 데이터 API와 같은 API 서비스에 연결하는 경우 세션을 직접 관리할 수 있습니다.

HTTPS를 통해 직접 사용자를 인증하고 사용자 액세스 토큰을 받거나 Realm SDK에서 관리하는 세션을 통해 이를 수행할 수 있습니다.

HTTPS를 통해 App Services에 직접 인증 요청을 보내 액세스 토큰을 얻을 수 있습니다. 인증 엔드포인트는 사용자의 로그인 자격 증명이 포함된 JSON 본문이 포함된 HTTPS POST 요청을 수락합니다. 자격 증명이 유효하면 응답에 사용자 액세스 토큰이 포함됩니다.

1

앱의 인증 엔드포인트 URL은 앱의 배포 모델에 따라 다릅니다.

앱의 배포 모델을 선택하면 기본 URL을 구성하는 방법을 확인할 수 있습니다.

https://services.cloud.mongodb.com/api/client/v2.0/app/<App ID>

<App ID> 을 클라이언트 앱 ID 로 바꿉니다. 예를 예시myapp-abcde 입니다.

https://<Region>.<Cloud>.services.cloud.mongodb.com/api/client/v2.0/app/<App ID>
  • <Region> 을(를) 앱이 호스팅되는 리전으로 바꿉니다. 예: us-east-1.

  • <Cloud> 을(를) 앱이 호스팅되는 클라우드로 바꿉니다. 예를 들어 aws, azure 또는 gcp 입니다.

  • <App ID> 을 클라이언트 앱 ID로 바꿉니다. 예시: myapp-abcde

앱 위치 엔드포인트를 사용하여 프로그래밍 방식으로 기본 URL을 찾을 수 있습니다. 응답 본문에는 기본 URL이 hostname 필드로 포함됩니다.

curl 'https://services.cloud.mongodb.com/api/client/v2.0/app/<App ID>/location'
{
"deployment_model": "LOCAL",
"location": "US-VA",
"hostname": "https://us-east-1.aws.services.cloud.mongodb.com",
"ws_hostname": "wss://ws.us-east-1.aws.services.cloud.mongodb.com"
}
2

사용자를 인증하려면 인증 제공자를 지정하여 로그인 엔드포인트를 호출합니다. 로그인 엔드포인트는 <Base URL>/auth/providers/<ProviderType>/login이며, 여기서 <ProviderType>은(는) 다음 유형 중 하나입니다:

  • anon-user

  • local-userpass

  • api-key

  • custom-token

  • custom-function

로그인 엔드포인트를 기본 URL에 추가하고 선택한 제공자 유형에 대한 사용자의 로그인 자격 증명이 포함된 JSON 본문이 포함된 HTTPS POST 요청을 보냅니다.

curl -X POST 'https://services.cloud.mongodb.com/api/client/v2.0/app/myapp-abcde/auth/providers/anon-user/login'
curl -X POST 'https://services.cloud.mongodb.com/api/client/v2.0/app/myapp-abcde/auth/providers/local-userpass/login' \
--header 'Content-Type: application/json' \
--data-raw '{
"username": "test@example.com",
"password": "Pa55w0rd"
}'
curl -X POST 'https://services.cloud.mongodb.com/api/client/v2.0/app/myapp-abcde/auth/providers/api-key/login' \
--header 'Content-Type: application/json' \
--data-raw '{
"key": "hScMWZyOKnjQMbfDPMJ1qHgtdGT2raQXdVDDvlC2SzKEBKlHKV8FK9SPCSTnODPg"
}'
curl -X POST 'https://services.cloud.mongodb.com/api/client/v2.0/app/myapp-abcde/auth/providers/custom-token/login' \
--header 'Content-Type: application/json' \
--data-raw '{
"token": "eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJhdWQiOiJ0ZXN0ZGV2LWJwcWVsIiwiZXhwIjoxNTE2MjM5MDIyLCJzdWIiOiIyNDYwMSIsInVzZXJfZGF0YSI6eyJuYW1lIjoiSmVhbiBWYWxqZWFuIiwiYWxpYXNlcyI6WyJNb25zaWV1ciBNYWRlbGVpbmUiLCJVbHRpbWUgRmF1Y2hlbGV2ZW50IiwiVXJiYWluIEZhYnJlIl19fQ.mVWr4yFf8nD1EhuhrJbgKfY7BEpMab38RflXzUxuaEI"
}'
curl -X POST 'https://services.cloud.mongodb.com/api/client/v2.0/app/myapp-abcde/auth/providers/custom-function/login' \
--header 'Content-Type: application/json' \
--data-raw '{
"someCustomFunctionArg": "<Login Info>"
}'

인증 요청이 성공하면 응답 본문에 사용자에 대한 access_tokenrefresh_token 값이 포함됩니다. access_token은 요청을 인증하는 데 사용할 수 있는 JWT(JSON Web Token)입니다.

{
"access_token": "eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJiYWFzX2RldmljZV9pZCI6IjAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMCIsImJhYXNfZG9tYWluX2lkIjoiNWVlYTg2NjdiY2I0YzgxMGI2NTFmYjU5IiwiZXhwIjoxNjY3OTQwNjE4LCJpYXQiOjE2Njc5Mzg4MTgsImlzcyI6IjYzNmFiYTAyMTcyOGI2YzFjMDNkYjgzZSIsInN0aXRjaF9kZXZJZCI6IjAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMCIsInN0aXRjaF9kb21haW5JZCI6IjVlZWE4NjY3YmNiNGM4MTBiNjUxZmI1OSIsInN1YiI6IjYzNmFiYTAyMTcyOGI2YzFjMDNkYjdmOSIsInR5cCI6ImFjY2VzcyJ9.pyq3nfzFUT-6r-umqGrEVIP8XHOw0WGnTZ3-EbvgbF0",
"refresh_token": "eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJiYWFzX2RhdGEiOm51bGwsImJhYXNfZGV2aWNlX2lkIjoiMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwIiwiYmFhc19kb21haW5faWQiOiI1ZWVhODY2N2JjYjRjODEwYjY1MWZiNTkiLCJiYWFzX2lkIjoiNjM2YWJhMDIxNzI4YjZjMWMwM2RiODNlIiwiYmFhc19pZGVudGl0eSI6eyJpZCI6IjYzNmFiYTAyMTcyOGI2YzFjMDNkYjdmOC1ud2hzd2F6ZHljbXZycGVuZHdkZHRjZHQiLCJwcm92aWRlcl90eXBlIjoiYW5vbi11c2VyIiwicHJvdmlkZXJfaWQiOiI2MjRkZTdiYjhlYzZjOTM5NjI2ZjU0MjUifSwiZXhwIjozMjQ0NzM4ODE4LCJpYXQiOjE2Njc5Mzg4MTgsInN0aXRjaF9kYXRhIjpudWxsLCJzdGl0Y2hfZGV2SWQiOiIwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMDAiLCJzdGl0Y2hfZG9tYWluSWQiOiI1ZWVhODY2N2JjYjRjODEwYjY1MWZiNTkiLCJzdGl0Y2hfaWQiOiI2MzZhYmEwMjE3MjhiNmMxYzAzZGI4M2UiLCJzdGl0Y2hfaWRlbnQiOnsiaWQiOiI2MzZhYmEwMjE3MjhiNmMxYzAzZGI3Zjgtbndoc3dhemR5Y212cnBlbmR3ZGR0Y2R0IiwicHJvdmlkZXJfdHlwZSI6ImFub24tdXNlciIsInByb3ZpZGVyX2lkIjoiNjI0ZGU3YmI4ZWM2YzkzOTYyNmY1NDI1In0sInN1YiI6IjYzNmFiYTAyMTcyOGI2YzFjMDNkYjdmOSIsInR5cCI6InJlZnJlc2gifQ.h9YskmSpSLK8DMwBpPGuk7g1s4OWZDifZ1fmOJgSygw",
"user_id": "636aba021728b6c1c03db7f9"
}

Realm SDK에서는 로그인한 사용자의 User 객체에서 로그인한 사용자의 액세스 토큰에 액세스할 수 있습니다. SDK는 SDK 작업을 위해 만료된 액세스 토큰을 자동으로 새로 고침하며, 메서드를 호출하여 수동으로 새로 고침할 수 있습니다.

자세히 알아보려면 사용 중인 Realm SDK의 설명서를 참조하세요:

액세스 토큰은 부여되고 30분 후에 만료됩니다. 액세스 토큰이 만료될 경우, 계속해서 요청을 보내려면 새 액세스 토큰을 받아야 합니다.

사용자를 다시 로그인하여 새 액세스 토큰을 얻을 수 있지만, 그러려면 사용자가 자격 증명을 다시 입력해야 합니다. 대신 사용자의 세션과 연결된 새로 고침 토큰을 사용하여 향후 30분 동안 유효한 새 액세스 토큰을 가져올 수 있습니다.

로그인 성공 후 액세스 토큰과 동일한 응답 내에서 새로 고침 토큰을 받습니다.

세션 새로 고침 엔드포인트는 Authorization 헤더에 새로 고침 토큰이 포함된 POST 요청을 수락합니다. 엔드포인트 URL은 앱의 배포 모델에 따라 달라집니다.

curl -X POST 'https://services.cloud.mongodb.com/api/client/v2.0/auth/session' \
--header 'Content-Type: application/json' \
--header 'Authorization: Bearer <RefreshToken>'
{
"access_token": "eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJiYWFzX2RldmljZV9pZCI6IjAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMCIsImJhYXNfZG9tYWluX2lkIjoiNWVlYTg2NjdiY2I0YzgxMGI2NTFmYjU5IiwiZXhwIjoxNjY3OTQzOTc5LCJpYXQiOjE2Njc5NDIxNzksImlzcyI6IjYzNmFjNzAyMDE5ZDJkYmY0NzUxMDRjMiIsInN0aXRjaF9kZXZJZCI6IjAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMCIsInN0aXRjaF9kb21haW5JZCI6IjVlZWE4NjY3YmNiNGM4MTBiNjUxZmI1OSIsInN1YiI6IjYzNmFjNzAyMDE5ZDJkYmY0NzUxMDQ5MyIsInR5cCI6ImFjY2VzcyJ9.pF3DR-096Ujt9-0KOWJTU25ZuryvwMfeCI7TiHJERNg"
}
  • <Region> 을(를) 앱이 호스팅되는 리전으로 바꿉니다. 예: us-east-1.

  • <Cloud> 을(를) 앱이 호스팅되는 클라우드로 바꿉니다. 예를 들어 aws, azure 또는 gcp 입니다.

curl -X POST 'https://<Region>.<Cloud>.services.cloud.mongodb.com/api/client/v2.0/auth/session' \
--header 'Content-Type: application/json' \
--header 'Authorization: Bearer <RefreshToken>'
{
"access_token": "eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJiYWFzX2RldmljZV9pZCI6IjAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMCIsImJhYXNfZG9tYWluX2lkIjoiNWVlYTg2NjdiY2I0YzgxMGI2NTFmYjU5IiwiZXhwIjoxNjY3OTQzOTc5LCJpYXQiOjE2Njc5NDIxNzksImlzcyI6IjYzNmFjNzAyMDE5ZDJkYmY0NzUxMDRjMiIsInN0aXRjaF9kZXZJZCI6IjAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMCIsInN0aXRjaF9kb21haW5JZCI6IjVlZWE4NjY3YmNiNGM4MTBiNjUxZmI1OSIsInN1YiI6IjYzNmFjNzAyMDE5ZDJkYmY0NzUxMDQ5MyIsInR5cCI6ImFjY2VzcyJ9.pF3DR-096Ujt9-0KOWJTU25ZuryvwMfeCI7TiHJERNg"
}

Realm SDK는 요청 시 토큰이 만료된 경우 로그인한 사용자의 액세스 토큰을 자동으로 새로 고칩니다.

또한 SDK를 사용하면 User 객체에서 메서드를 호출하여 사용자의 액세스 토큰을 수동으로 새로 고칠 수 있습니다.

자세히 알아보려면 사용 중인 Realm SDK의 설명서를 참조하세요:

기본적으로 새로 고침 토큰은 발행 후 60일이 지나면 만료됩니다. 앱의 새로 고침 토큰 만료 간격을 30분에서 5년 사이로 구성할 수 있습니다.

익명 사용자 새로 고침 토큰은 만료 시간이 길고 사실상 만료되지 않습니다. 대신 익명 사용자 계정은 생성된 지 90일이 지나면 자동으로 삭제됩니다.

Admin UI 또는 Admin API에서 앱의 모든 세션에 대한 새로 고침 토큰 만료 시간을 구성할 수 있습니다.

관리자 UI에서 앱의 모든 세션에 대한 토큰 새로 고침 만료 시간을 설정하려면 다음과 같이 하세요:

  1. 왼쪽 탐색 메뉴에서 App Users를 클릭합니다.

  2. 0}User Settings 탭을 선택합니다.

  3. Refresh Token Expiration 옵션을 찾아 Edit 버튼을 클릭합니다.

  4. 텍스트 입력란에 시간 값을 입력하고 적절한 시간 단위(예: '분' 또는 '일')를 드롭다운 메뉴에서 선택합니다.

  5. Save를 클릭합니다.

Admin API에서 앱의 모든 세션에 대한 새로 고침 토큰 만료 시간을 설정하려면 요청 본문의 expiration_time_seconds 필드를 원하는 만료 시간으로 설정하고 앱의 사용자 새로 고침 토큰 만료 시간 설정 엔드포인트를 호출합니다.

curl -X PUT \
https://services.cloud.mongodb.com/api/admin/v3.0/groups/{groupId}/apps/{appId}/security/refresh_token_expiration \
--data-raw '{
"expiration_time_seconds": 864000
}'

새로 고침 토큰 만료 시간을 성공적으로 업데이트하면 엔드포인트가 204 응답을 반환합니다.

액세스 토큰을 디코딩하여 형식이 올바른지, 서명이 유효한지 확인할 수 있습니다. 디코딩된 응답에는 액세스 토큰이 만료되는 시기 등 기타 정보가 포함됩니다.

요청 본문의 token 필드에 있는 토큰을 사용하여 앱의 액세스 토큰 확인 및 디코딩 Admin API 엔드포인트를 호출합니다.

curl -X POST \
https://services.cloud.mongodb.com/api/admin/v3.0/groups/{groupId}/apps/{appId}/users/verify_token \
--data-raw '{
"token": "eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJiYWFzX2RldmljZV9pZCI6IjAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMCIsImJhYXNfZG9tYWluX2lkIjoiNWNkYjEyNDA4ZTIzMmFjNGY5NTg3ZmU4IiwiZXhwIjoxNjc2NTExMjgyLCJpYXQiOjE2NzY1MDk0ODIsImlzcyI6IjYzZWQ4MTJhNDNiZTcyYzE3NmFhNWQyMyIsInN0aXRjaF9kZXZJZCI6IjAwMDAwMDAwMDAwMDAwMDAwMDAwMDAwMCIsInN0aXRjaF9kb21haW5JZCI6IjVjZGIxMjQwOGUyMzJhYzRmOTU4N2ZlOCIsInN1YiI6IjYzZWQ4MTJhNDNiZTcyYzE3NmFhNWQyMSIsInR5cCI6ImFjY2VzcyJ9.7kHO9wjWvIaD3VewDyPhLyb-oRc7wTYZdD9-hroF-H4"
}'
{
"sub": "63ed812a43be72c176aa5d21",
"exp": 1676511282,
"iat": 1676509482,
"iss": "63ed812a43be72c176aa5d23",
"domain_id": "5cdb12408e232ac4f9587fe8",
"device_id": "000000000000000000000000"
}

토큰이 유효하면 200 응답을 받게 됩니다.

토큰이 유효하지만 만료된 경우 응답은 디코딩된 JWT를 포함하지 않고 토큰이 만료되었음을 나타냅니다.

"token expired"

토큰이 유효하지 않으면 오류 메시지가 포함된 401 응답을 받게 됩니다.

{
"error": "signature is invalid"
}

세션이 설정된 후에는 사용자의 모든 활성 세션을 취소할 수는 있지만 개별적으로 세션을 종료할 수는 없습니다.

액세스 토큰 및 새로 고침 토큰의 모든 사본을 삭제하여 사용자 세션을 효과적으로 종료할 수 있습니다. 이렇게 하면 세션에 대한 추가 액세스가 방지되고 계속하려면 사용자가 인증하고 새 세션을 시작해야 합니다.

각 Realm SDK에는 액세스 토큰과 새로 고침 토큰의 로컬 사본을 삭제하고 새 액세스 토큰을 가져오는 데 사용할 수 없도록 새로 고침 토큰을 무효화하는 User.logOut() 메서드가 있습니다.

관리자나 사용자에 의해 사용자 계정이 삭제되면 사용자의 모든 세션이 자동으로 해지됩니다.

중요

토큰 보안 유지

보유하고 있는 토큰의 모든 사본을 삭제하고 무효화하더라도 서버에서 활성 세션이 종료되지는 않습니다. 악의적인 사용자가 액세스 토큰이 삭제되기 전에 복사한 경우, 해당 토큰을 사용하여 토큰이 만료될 때까지 최대 30분 동안 요청을 수행할 수 있습니다. 이러한 요청은 '로그아웃한 사용자'가 보낸 것으로 보입니다.

사용자의 현재 세션을 모두 해지할 수 있습니다. 이렇게 하면 세션 액세스 및 새로 고침 토큰이 무효화되고 사용자가 다시 로그인할 때까지 어떤 기기에서든 요청을 수행할 수 없습니다.

관리자나 사용자가 사용자 계정을 삭제하면 해당 사용자의 모든 세션이 자동으로 취소됩니다.

  1. 왼쪽 탐색 메뉴에서 App Users 을 선택합니다.

  2. Users 탭의 목록에서 사용자를 찾아 줄임표(...)를 클릭합니다.

  3. Revoke all sessions를 클릭합니다.

사용자의 모든 세션을 취소하려면 appservices users revoke 을(를) 호출합니다. CLI 는 앱 ID 를 입력하라는 메시지를 표시하고 선택할 수 있도록 해당 앱 의 사용자를 나열합니다.

appservices users revoke

명령을 실행 때 인수를 지정할 수도 있습니다.

appservices users revoke \
--app=<Your App ID> \
--user=<User ID>

여러 사용자의 id 값을 쉼표로 구분된 목록으로 지정하여 단일 명령으로 여러 사용자의 세션을 취소할 수 있습니다.

appservices users revoke --user=6099694d5debcbcc873ff413,60996996b78eca4a8d615d3a

사용자 세션 취소 엔드포인트를 호출합니다.

엔드포인트 URL에서 다음 값을 바꿔야 합니다.

curl -X PUT \
-H 'Authorization: Bearer {access_token}' \
https://services.cloud.mongodb.com/api/admin/v3.0/groups/{groupId}/apps/{appId}/users/{userId}/logout