- HOME
- Compute
- Server
- Server 개요
- Server 사용 준비
- Server 시나리오
- Server 시작
- Server 사용
- Server 접속
- Server 권한 관리
- Server 반납
- Server 문제 해결
- Server 문제 해결
- 서버이미지(OS) 라이프사이클
- 강제 정지 및 강제 반납
- Xentools 재설치(Windows)
- Xentools 재설치 (Linux)
- Server Status Check
- 자동 마운트 설정(fstab)
- 서버 원격 접속 오류 지원(Windows)
- 서버 원격 접속 오류 지원(Linux)
- 패키지 명령어 이슈 점검 (Linux)
- 진단 인터럽트
- DNS 설정 점검
- 시간 동기화 설정 점검
- Ncloud Tool Kit 점검 (Windows)
- Ncloud Tool Kit 점검 (Linux)
- VPC 서버 접속 환경 구성
- 서버 복구
- 파일시스템 오류 복구 가이드
- KVM Guest Agent 점검(Linux)
- Linux OS Repository 설정 점검
- Server 활용 툴
- 커널 업데이트
- Server 릴리스 노트
- Cloud Functions
- Auto Scaling
- Server
- Containers
- Container Registry
- Ncloud Kubernetes Service
- Ncloud Kubernetes Service 개요
- Ncloud Kubernetes Service 사용 준비
- Ncloud Kubernetes Service 시작
- Ncloud Kubernetes Service 사용
- Ncloud Kubernetes Service 활용 예제
- Ncloud Kubernetes Service 문제 해결
- Ncloud Kubernetes Service 권한 관리
- Ncloud Kubernetes Service 릴리스 노트
- Storage
- Networking
- Database
- Cloud DB for MySQL
- Cloud DB for Redis
- Cloud DB for MSSQL
- Cloud DB for MongoDB
- Cloud DB for PostgreSQL
- Database Migration Service
- MSSQL
- MySQL
- CUBRID
- Redis
- PostgreSQL
- MariaDB
- Security
- ACG
- App Safer
- File Safer
- Security Monitoring
- SSL VPN
- System Security Checker
- Compliance Guide
- Key Management Service
- Key Management Service 개요
- Key Management Service 개념
- Key Management Service 사용 준비
- Key Management Service 시나리오
- Key Management Service 시작
- Key Management Service 사용
- Key Management Service 예제
- Key Management Service 리소스 관리
- Key Management Service 권한 관리
- Key Management Service 용어
- Key Management Service 릴리스 노트
- Certificate Manager
- Web Security Checker
- Hardware Security Module
- Webshell Behaivor Detector
- Cloud Security Watcher
- AI Services
- CLOVA AiCall
- CLOVA Chatbot
- CLOVA Speech
- CLOVA OCR
- CLOVA eKYC
- Papago Translation
- Papago Image Translation
- TensorFlow
- AI·NAVER API
- Application Services
- Simple & Easy Notification Service
- Simple & Easy Notification Service 개요
- Simple & Easy Notification Service 사용 준비
- Simple & Easy Notification Service 시나리오
- Simple & Easy Notification Service 시작
- Simple & Easy Notification Service 사용
- Simple & Easy Notification Service 권한 관리
- Simple & Easy Notification Service 용어
- Simple & Easy Notification Service 릴리스 노트
- API Gateway
- GeoLocation
- Cloud Outbound Mailer
- Simple & Easy Notification Service
- Big Data & Analytics
- Cloud Hadoop
- Cloud Hadoop 개요
- Cloud Hadoop 이용 시나리오
- Cloud Hadoop 사용 준비
- Cloud Hadoop 시작
- Cloud Hadoop 사용
- Cloud Hadoop ecosystem 활용
- Ambari UI
- Ambari REST API 사용
- Apache Livy로 Spark Job 제출
- Custom Alerts 설정
- Hive 사용
- Hive UDF 실행
- Hive External Table로 CSV 파일 연동
- Hive External Table로 json 파일 연동
- Hue 사용
- Impala 사용
- Kudu 사용
- MySQL Stored Procedure로 DB 생성 및 계정 관리
- OpenTSDB 사용
- Presto(Trino) 사용
- Presto(Trino)로 Hive warehouse 데이터 분석
- Ranger Plugin으로 접근제어 설정
- Ranger를 통한 사용자별 HDFS 접근권한 관리
- Spark Scala Job 제출
- Sqoop 사용
- Sqoop + Oozie Workflow를 활용한 MySQL 8.0 마이그레이션
- Zeppelin 사용
- Iceberg 사용
- NiFi 사용
- Cloud Hadoop 연동
- Cloud Hadoop 리소스 관리
- Cloud Hadoop 권한 관리
- Cloud Hadoop 릴리스 노트
- Search Engine Service
- Search Engine Service 개요
- Search Engine Service 개념
- Search Engine Service 시나리오
- Search Engine Service 사용 준비
- Search Engine Service 시작
- Search Engine Service 사용
- Search Engine Service 예제
- Search Engine Service 권한 관리
- Kibana/Opensearch 활용
- Search Engine Service 용어
- Search Engine Service FAQ
- Search Engine Service 릴리스 노트
- Cloud Data Streaming Service
- Cloud Data Streaming Service 개요
- Cloud Data Streaming Service 사용 준비
- Cloud Data Streaming Service 개념
- Cloud Data Streaming Service 시작
- Cloud Data Streaming Service 사용
- Cloud Data Streaming Service 예제
- Cloud Data Streaming Service 권한 관리
- Cloud Data Streaming Service 용어
- Cloud Data Streaming Service FAQ
- Cloud Data Streaming Service 릴리스 노트
- Cloud Hadoop
- Content Delivery
- Developer Tools
- Hybrid & Private Cloud
- Management & Governance
- Resource Manager
- Web service Monitoring System
- Cloud Log Analytics
- Sub Account
- Service Quota
- Cost Explorer
- Cloud Activity Tracer
- Network Traffic Monitoring
- Cloud Insight
- Pinpoint Cloud
- Organization
- Notification Recipient
- Ncloud Single Sign-On
- Control Panel
- Media
- VOD Station
- Live Station
- Media Connect Center
- Migration
등록한 Application을 Ncloud Single Sign-On에 연동하는 방법을 설명합니다. 연동은 Ncloud Single Sign-On에서 제공하는 연동 API를 통해 진행합니다. Ncloud Single Sign-On 연동 API가 제공하는 기능은 다음과 같습니다.
- Ncloud Single Sign-On 연동 API를 사용하기 전에 OAuth 2.0과 관련된 주요 개념을 Ncloud Single Sign-On 개념에서 학습하는 것을 권장합니다.
- 여기에서는 Ncloud Single Sign-On 연동 시 사용하는 API만 설명합니다. 네이버 클라우드 플랫폼의 Ncloud Single Sign-On이 제공하는 전체 API에 대한 설명은 Ncloud Single Sign-On API 가이드를 참고해 주십시오.
권한 부여
Resource Owner와 상호 작용하고 보호된 리소스에 접근하는 권한을 부여받기 위해 필요한 API를 설명합니다.
요청
Client가 보호된 리소스에 접근할 수 있도록 IDP에 보내는 요청은 다음과 같습니다.
GET /tenants/{Tenant Id or Alias}/oauth2/authorize
- 요청 Path
파라미터명 타입 필수 여부 제약 사항 설명 Tenant Id or Alias
String 필수 - Tenant 생성 시 발급받은 Tenant ID 또는 Tenant Alias - 요청 파라미터
파라미터명 타입 필수 여부 제약 사항 설명 response_type
String 필수 code
또는token
Authorization Code 또는 Implicit 플로우 진행 시 필요한 값 client_id
String 필수 - Application 등록 시 발급받은 Client ID redirect_uri
String 필수 Application 등록 시 입력한 Redirect URI와 반드시 일치 권한 부여 완료 후 이동하게 되는 페이지의 URL scope
String 필수 - 접근 가능 범위. 추가 범위를 요청하기 위해서는 하나 이상의 범위 값을 공백으로 구분하여 포함. state
String 선택 - CSRF 방어를 위한 임의의 값. state 권한 부여 완료 후 state를 포함해 redirect_uri
에 입력한 페이지로 이동code_challenge
String 선택 Access Type
이 public일 경우 사용PKCE 적용 시 필요한 Code Challenge의 값 code_challenge_method
String 선택 Access Type
이 public일 경우 사용,plain
또는S256
PKCE 적용 시 필요한 Code Challenge Method의 값
예시는 다음과 같습니다.
response_type
이code
인 경우GET /tenants/{Tenant Id or Alias}/oauth2/authorize?client_id=${Client Id}&scope=${Scope}&response_type=code&redirect_uri=${Redirect URI}&state=${State} HTTP/1.1 Host: sso.ncloud.com
Plain textcode_challenge
및code_challenge_method
를 추가하여 권한 부여를 요청한 경우GET /tenants/{Tenant Id or Alias}/oauth2/authorize?client_id=${Client Id}&scope=${Scope}&response_type=code&redirect_uri=${Redirect URI}&state=${State}&code_challenge=${Code Challenge}&code_challenge_method=${Code Challenge Method} HTTP/1.1 Host: sso.ncloud.com
Plain textresponse_type
이token
인 경우GET /tenants/{Tenant Id or Alias}/oauth2/authorize?client_id=${Client Id}&scope=${Scope}&response_type=token&redirect_uri=${Redirect URI}&state=${State} HTTP/1.1 Host: sso.ncloud.com
Plain text
응답
요청에 대한 응답은 다음과 같습니다.
response_type
이code
인 경우HTTP/1.1 302 Found Location: {Redirect URI} ?code=${Authorization code} &state=${State}
Plain text파라미터명 타입 필수 여부 제약 사항 설명 redirect_uri
String 필수 요청 시 포함한 redirect_uri
권한 부여 완료 후 이동하게 되는 페이지의 URL code
String 필수 유출 위험을 방지하기 위해 1분 후 만료 IDP에서 생성한 Authorization code state
String 선택 - Client가 요청한 값 response_type
이token
인 경우HTTP/1.1 302 Found Location: {Redirect URI} ?access_token={Access Token} &token_type=Bearer &expires_in={Access Token Expire Date} &state={State}
Plain text파라미터명 타입 필수 여부 제약 사항 설명 redirect_uri
String 필수 요청 시 포함한 redirect_uri
권한 부여 완료 후 이동하게 되는 페이지의 URL access_token
String 필수 - 권한이 부여된 Access Token expires_in
Number 필수 - Access Token의 유효 기간 state
String 선택 - Client가 요청한 값
Token 발급
접근 권한이 부여된 후 자격 증명을 위한 Token을 발급받기 위해 필요한 API를 설명합니다.
요청
권한 부여 후에, 또는 Refresh Token을 사용하여 Access Token이나 ID Token을 발급받기 위해 보내는 요청은 다음과 같습니다.
POST /tenants/{Tenant Id or Alias}/oauth2/token
- 요청 Path
파라미터명 타입 필수 여부 제약 사항 설명 Tenant Id or Alias
String 필수 - Tenant 생성 시 발급받은 Tenant ID 또는 Tenant Alias - 요청 헤더
헤더명 타입 필수 여부 제약 사항 설명 Authorization
String 선택 Access Type
이 public일 경우 사용, Basic Base64({Client Id}:{Client Secret})
Client 식별자 Content-Type
String 필수 application/x-www-form-urlencoded
리소스의 미디어 타입 - 요청 파라미터
파라미터명 타입 필수 여부 제약 사항 설명 grant_type
String 필수 authorization_code
또는refresh_token
Token 반환 방식 code
String 선택 grant_type
이authorization_code
일 경우 사용IDP가 전달한 Authorization code redirect_uri
String 선택 grant_type
이authorization_code
일 경우 사용권한 부여 요청 시 포함한 redirect_uri
scope
String 선택 grant_type
이refresh_token
일 경우 사용수정할 scope
code_verifier
String 선택 Access Type
이 public일 경우 사용 ,grant_type
이authorization_code
일 경우 사용되며, 기존에 부여한scope
의 범위보다 같거나 작아야 함권한 부여 요청 시 포함한 code_challenge
,code_challenge_method
에 대응되는 값client_id
String 선택 Access Type
이 public일 경우 사용Application 등록 시 발급받은 Client ID
예시는 다음과 같습니다.
권한 부여 후 Authorization code를 포함하여 Access Token 발급을 요청할 경우
POST /tenants/{Tenant Id or Alias}/oauth2/token HTTP/1.1 Host: sso.ncloud.com Authorization: Basic Base64(${Client Id}:${Client Secret}) Content-Type: application/x-www-form-urlencoded grant_type=authorization_code&code=${Authorization code}&redirect_uri=${Redirect URI}
Plain text권한 부여 후 Access Token 발급 요청에
code_verifier
가 포함된 경우POST /tenants/{Tenant Id or Alias}/oauth2/token HTTP/1.1 Host: sso.ncloud.com Authorization: Basic Base64(${Client Id}:${Client Secret}) Content-Type: application/x-www-form-urlencoded grant_type=authorization_code&code=${Authorization code}&redirect_uri=${Redirect URI}&code_verifier=${Code Verifier}&client_id=${Client Id}
Plain textRefresh Token으로 Access Token 발급을 요청할 경우
POST /tenants/{Tenant Id or Alias}/oauth2/token HTTP/1.1 Host: sso.ncloud.com Authorization: Basic Base64(${Client Id}:${Client Secret}) Content-Type: application/x-www-form-urlencoded grant_type=refresh_token&refresh_token=${Refresh Token}&scope=${Scope}
Plain text
응답
요청에 대한 응답은 다음과 같습니다.
{
"access_token": "String",
"token_type": "Bearer",
"expires_in": "Number",
"refresh_token": "String"
}
파라미터명 | 타입 | 필수 여부 | 제약 사항 | 설명 |
---|---|---|---|---|
access_token | String | 필수 | - | 권한이 부여된 Access Token |
token_type | String | 필수 | Bearer | Token의 형식 |
expires_in | Number | 필수 | - | Access Token의 유효 기간 |
refresh_token | String | 필수 | - | Access Token 발급 시 사용되는 Refresh Token의 값 |
Token 취소
Access Token 또는 Refresh Token을 취소할 때 필요한 API를 설명합니다.
요청
Access Token 또는 Refresh Token을 취소하기 위해 보내는 요청은 다음과 같습니다.
POST /tenants/{Tenant Id or Alias}/oauth2/revoke
- 요청 Path
파라미터명 타입 필수 여부 제약 사항 설명 Tenant Id or Alias
String 필수 - Tenant 생성 시 발급받은 Tenant ID 또는 Tenant Alias - 요청 헤더
헤더명 타입 필수 여부 제약 사항 설명 Authorization
String 필수 Basic Base64 ({Client Id}:{Client Secret})
Client 식별자 Content-Type
String 필수 application/x-www-form-urlencoded
리소스의 미디어 타입 - 요청 파라미터
파라미터명 타입 필수 여부 제약 사항 설명 token
String 필수 - 취소하려는 Token token_type_hint
String 필수 access_token
또는refresh_token
취소하려는 Token의 타입
응답
요청에 대한 응답은 다음과 같습니다.
{
"status": "ok"
}
인증된 사용자의 클레임 반환
인증된 사용자에 대한 클레임을 반환하기 위해 필요한 API를 설명합니다.
요청
사용자 클레임을 반환하기 위해 보내는 요청은 다음과 같습니다.
POST /tenants/{Tenant Id or Alias}/oauth2/userinfo
- 요청 Path
파라미터명 타입 필수 여부 제약 사항 설명 Tenant Id or Alias
String 필수 - Tenant 생성 시 발급받은 Tenant ID 또는 Tenant Alias - 요청 헤더
헤더명 타입 필수 여부 제약 사항 설명 Authorization
String 필수 Bearer {AccessToken}
Client 식별자
응답
요청에 대한 응답은 다음과 같습니다.
{
"sub" : "String",
"id_no" : "String",
"user_type" : "String",
"user_id": "String",
"user_name" : "String",
"mbr_no" : "Number"
"groups" : "List"
}
파라미터명 | 타입 | 필수 여부 | 제약 사항 | 설명 |
---|---|---|---|---|
sub | String | 필수 | - | Subject(end-user) 식별자 |
id_no | String | 필수 | - | 네이버 클라우드 플랫폼에서 사용되는 사용자 식별자 |
user_type | String | 필수 | Customer 또는 Sub | 사용자 유형 |
user_id | String | 필수 | - | 로그인 아이디 |
user_name | String | 필수 | - | 사용자 이름 |
mbr_no | Number | 필수 | - | 사용자의 회원 번호 |
groups | List | 선택 | - | user_type 이 Sub 일 때 subAccount가 속한 그룹명 목록 |
ID Token 서명 키 반환
ID Token의 서명에 사용되는 공개 키를 반환할 때 필요한 API를 설명합니다.
요청
ID Token 서명에 사용되는 공개 키를 반환하기 위해 보내는 요청은 다음과 같습니다.
GET /tenants/{Tenant Id or Alias}/oauth2/jwks
- 요청 Path
파라미터명 타입 필수 여부 제약 사항 설명 Tenant Id or Alias
String 필수 - Tenant 생성 시 발급받은 Tenant ID 또는 Tenant Alias
응답
요청에 대한 응답은 다음과 같습니다.
{
"keys" : [ {
"kty" : "String",
"e" : "String",
"kid" : "String",
"n" : "String"
} ]
}
파라미터명 | 타입 | 필수 여부 | 제약 사항 | 설명 |
---|---|---|---|---|
kty | String | 필수 | - | IETF Datatracker의 Key Type 참고 |
e | String | 필수 | - | IETF Datatracker의 RSA Exponent 참고 |
kid | String | 필수 | - | IETF Datatracker의 Key ID 참고 |
n | String | 필수 | - | IETF Datatracker의 RSA Modulus 참고 |
Endpoint
API의 Endpoint는 다음과 같습니다.
Endpoint | URI Path | 설명 |
---|---|---|
Authorization Endpoint | /tenants/{Tenant Id or Alias}/oauth2/authorize | Client가 Resource Owner와 상호 작용하고 보호된 리소스에 접근할 수 있는 권한 부여 요청 |
Token Endpoint | /tenants/{Tenant Id or Alias}/oauth2/token | 접근 권한 또는 Refresh Token을 통해 Access Token, ID Token 발급 |
Token Revocation Endpoint | /tenants/{Tenant Id or Alias}/oauth2/revoke | Access Token 또는 Refresh Token 취소 |
User Info Endpoint | /tenants/{Tenant Id or Alias}/oauth2/userinfo | 인증된 사용자에 대한 클레임 반환 |