PortOne REST API - V1
결제완료된 정보, 결제취소, 상태별 결제목록 조회 등의 기능을 하는 REST API를 제공합니다.
비인증 결제, 정기 자동결제 등 부가기능을 위한 REST API도 제공합니다.
V1 API hostname: api.iamport.kr
인증 관련 API
포트원 API를 호출할 때는 액세스 토큰을 Authorization
헤더에 넣어주어야 합니다.
액세스 토큰은
액세스 토큰 발급 API를 호출하려면 API 키와 API 시크릿을 인자로 넣어주어야 합니다.
API 키와 API 시크릿 확인하기
API 키와 API 시크릿 확인하기
- 관리자 콘솔
상점・계정 관리
화면 접속 내 식별코드・API Keys
버튼 클릭
API 시크릿은 절대로 외부에 노출되어서는 안되는 값입니다.
실제 구현에서 액세스 토큰 발급은 꼭 서버사이드에서 해주세요.
액세스 토큰 발급 받기
액세스 토큰 발급 받기
포트원 REST API 서버는 Google Public NTP의 시간과 동기화되고 있습니다.
하위 상점 연동을 할 경우 액세스 토큰을 발급받을 때 Agent 계정의 API 키 와 API 시크릿을 사용해야 합니다.
액세스 토큰 사용하기
액세스 토큰 사용하기
발급받은 액세스 토큰은 다른 API를 호출할 때
Authorization
헤더에 Bearer <액세스 토큰>
형식의 값을 넣어주면 됩니다.
자세한 내용은 MDN - HTTP 인증 문서를 참고해주세요.
하위 상점 연동을 할 경우 포트원 API 호출시 Tier
헤더에 하위 상점 티어 코드를 입력해야 합니다.
액세스 토큰 만료기한 연장
액세스 토큰 만료기한 연장
만료된 액세스 토큰으로 API를 호출하면 401 Unauthorized
응답을 받습니다.
액세스 토큰의 만료기한은 발행시간부터 30분입니다.
- 기존 액세스 토큰이 만료되기 전
access_token 발급 API post/users/getToken 를 다시 호출했을 경우- 기존 액세스 토큰이 반환됩니다.
만료기한이 1분 안쪽으로 남았을 때 요청했다면 기존 액세스 토큰의 만료시간이 5분 연장됩니다.
- 기존 액세스 토큰이 반환됩니다.
- 기존 액세스 토큰이 만료된 다음
access_token 발급 API post/users/getToken 를 다시 호출했을 경우- 새로운 액세스 토큰이 반환됩니다.
액세스 토큰의 재사용과 만료기한 5분 연장 동작방식은 다음과 같은 상황을 고려해서 설계되었습니다.
- 한 고객사에서 여러 대의 웹서버가 동시에 경쟁적으로 REST API(
/users/getToken
)를 호출하는 상황 - 한 고객사에서 여러 대의 웹서버가 시간 동기화 되어있지 않은 상황
결제 관련 API
목차
결제 금액 사전 등록 관련 API
비인증 결제 관련 API
정기 결제 관련 API
목차
빌링키 관련 API
목차
가상계좌 관련 API
PG사 관련 API
카카오 관련 API
KCP 퀵페이 관련 API
페이코 관련 API
페이먼트월 관련 API
본인인증 관련 API
현금영수증 관련 API
에스크로 관련 API
배송정보 단건조회 API
입력한 배송정보를 획득합니다.
택배사 코드표 : https://developers.portone.io/docs/ko/tip/code
지원되는 PG사
- KG이니시스
- NHN KCP
- 키움페이(구 다우, 페이조아)(다우테이타)
- KSNET
- 스마트로 - 신모듈(PG사와의 사전 계약이 반드시 필요합니다.)
- (신) 나이스페이
- 웰컴페이먼츠
Request
Path
배송정보를 조회하고자 하는 에스크로 결제건의 포트원 거래고유번호
Response
200
0이면 정상적인 조회, 0아닌 값이면 message를 확인해봐야 합니다
code값이 0이 아닐 때, '존재하지 않는 결제정보입니다'와 같은 오류 메세지를 포함합니다
에스크로 결제건의 택배사 코드
에스크로 결제건의 송장번호
에스크로 결제건의 배송 발송 시각 UNIX timestamp
에스크로 결제건의 배송 정보 등록 시각 UNIX timestamp
400
401
404
409
500
배송정보 단건수정 API
logis는 하위 필드가 모두 필수입니다.
sender, receiver의 각 세부 항목은 PG사마다 필수 여부가 모두 다릅니다.
지원되는 PG사
- KG이니시스
- 키움페이(구 다우, 페이조아)(다우테이타)
- KSNET
- 스마트로 - 신모듈 (PG사와의 사전 계약이 반드시 필요합니다.)
- 웰컴페이먼츠
Request
Path
배송정보를 수정하고자 하는 에스크로 결제건의 포트원 거래고유번호
Body
배송을 보내는 발신자의 정보(이름, 연락처, 주소, 우편번호, 수신자와의 관계)
배송을 받는 수신자의 정보(이름, 연락처, 주소, 우편번호)
택배사코드표는 메뉴얼 참조
배송 보내는 상품의 정보 (고유 아이디, 이름, 고유 코드, 통화코드, 수량, 카테고리)
가맹점에서 사용하는 상품 관리 코드
통화 e.g.) KRW, USD, VND, ... Default: KRW
상품의 수량으로 기본값은 1입니다.
상품의 카테고리 e.g) 도서, 가전기기, 인테리어 용품 등
Response
200
0이면 정상적인 조회, 0아닌 값이면 message를 확인해봐야 합니다
code값이 0이 아닐 때, '존재하지 않는 결제정보입니다'와 같은 오류 메세지를 포함합니다
에스크로 결제건의 택배사 코드
에스크로 결제건의 송장번호
에스크로 결제건의 배송 발송 시각 UNIX timestamp
에스크로 결제건의 배송 정보 등록 시각 UNIX timestamp
400
401
404
405
409
500
배송정보 단건등록 API
logis는 하위 필드가 모두 필수입니다.
sender, receiver의 각 세부 항목은 PG사마다 필수 여부가 모두 다릅니다.
지원되는 PG사
- KG이니시스
- NHN KCP
- 키움페이(구 다우, 페이조아)(다우테이타)
- KSNET
- 스마트로 - 신모듈(PG사와의 사전 계약이 반드시 필요합니다.)
- (신) 나이스페이
- 웰컴페이먼츠
Request
Path
배송정보를 등록하고자 하는 에스크로 결제건의 포트원 거래고유번호
Body
배송을 보내는 발신자의 정보(이름, 연락처, 주소, 우편번호, 발신자와의 관계)
배송을 받는 수신자의 정보(이름, 연락처, 주소, 우편번호)
택배사코드표는 매뉴얼 참조
배송 보내는 상품의 정보(고유 아이디, 이름, 고유 코드, 통화코드, 수량, 카테고리)
가맹점에서 사용하는 상품 관리 코드
통화 e.g.) KRW, USD, VND, ... Default: KRW
상품의 수량으로 기본값은 1입니다.
상품의 카테고리 e.g) 도서, 가전기기, 인테리어 용품 등
에스크로 구매 확정시 결제 창에 입력했던 이메일로 해당 사실을 전송할지 여부 (기본값 : true)
Response
200
0이면 정상적인 조회, 0아닌 값이면 message를 확인해봐야 합니다
code값이 0이 아닐 때, '존재하지 않는 결제정보입니다'와 같은 오류 메세지를 포함합니다
에스크로 결제건의 택배사 코드
에스크로 결제건의 송장번호
에스크로 결제건의 배송 발송 시각 UNIX timestamp
에스크로 결제건의 배송 정보 등록 시각 UNIX timestamp