[PAYJP-NODEJS] 결제 기능 구현
파 Y. KR
data:image/s3,"s3://crabby-images/a7f56/a7f560e56ff7190bc91754354d0bf66b66608265" alt=""
Pay.jp 관리 화면
data:image/s3,"s3://crabby-images/2bb0f/2bb0f18c34e66408e4052d2beeed0b7fb12c7051" alt=""
구현
1. API Key 취득
테스트 및 프로덕션 API 키가 있습니다.
data:image/s3,"s3://crabby-images/a8e24/a8e241a76dc69aa183c950493ab5de998f848020" alt=""
2. UI 작성
디자인된 결제 양식 사용(이 기사 사용 방법)
<script>
태그를 한 줄로, 디자인된 결제 폼, 카드 정보의 밸리데이션, 카드 정보의 토큰화를 실시하는 폼을 생성할 수가 있습니다.<script
type="text/javascript"
src="https://checkout.pay.jp/"
class="payjp-button"
data-key=PUBLIC_KEY
data-submit-text="トークンを作成する"
data-on-created="onCreated"
data-partial="true">
</script>
다음 버튼이 생성됩니다.
※onCreated는 카드 토큰 작성 후 실행되는 액션입니다. (
window.onCreated = funtion() {}
)data:image/s3,"s3://crabby-images/606e8/606e8ed4e3980b77d06daad236c68544e1a0b5d0" alt=""
클릭하면 카드 정보 입력 양식이 모달로 열립니다.
data:image/s3,"s3://crabby-images/b984e/b984ea1004790641a1fa391a795fb740dc091a57" alt=""
카드 정보의 유효성 검증에 문제가 없으면 카드 토큰 (
tok_ec73...
)이 작성됩니다.data:image/s3,"s3://crabby-images/9abbf/9abbf2ff6dd5d7f425213f0fc28cb9fdb5ea499e" alt=""
설계된 결제 양식 사용 참고
data:image/s3,"s3://crabby-images/cb26d/cb26dedabfa0eb898c78a9f4b4203f2f1b942419" alt=""
3. 뒷면 실장
SDK 설치 API Doc
npm install --save payjp
이용시
import pay from 'payjp'
const payjp = pay(PRIVATE_KEY);
결제
const pay = await payjp.charges.create({
amount: 1000,
currency: 'jpy',
card: 'tok_ec73...' // カードトークン
})
data:image/s3,"s3://crabby-images/5c559/5c5597b0c50fb7c6b9e9cfc7edd40aa28254512f" alt=""
카드 등록
고객을 만들어야합니다. API
const customer = await payjp.customers.create({
description: 'テスト',
email: "[email protected]"
})
// カード情報を取得する時、このユーザーの情報が必要ですので、Userモデルなどにcustomer.idを保存することが必要です。
카드 등록
const card = await payjp.customers.cards.create(customer.id, {
dcard: 'tok_ec73...', // カードトークン
default: true,
})
등록된 카드의 정보 취득
고객으로부터 카드 정보를 가져옵니다.
const cards = await payjp.customers.cards.list(customer.id)
data:image/s3,"s3://crabby-images/59db4/59db4e6c209abea9582c0a65c999af720122a526" alt=""
※ CardUI는 react-credit-cards를 사용하여 작성합니다.
정기 과금
계획 작성 필요
const plan = await payjp.plans.create({
amount: 1000,
currency: 'jpy',
interval: 'month',
trial_days: 30
});
data:image/s3,"s3://crabby-images/75c32/75c32ae1058b4ad4d7848b281ff196cce46fe065" alt=""
const subscription = await payjp.subscriptions.create({
plan: plan.id,
customer: customer.id
});
data:image/s3,"s3://crabby-images/4f08e/4f08e1031f6b6962149732dad9d48fcf20bbdd20" alt=""
Reference
이 문제에 관하여([PAYJP-NODEJS] 결제 기능 구현), 우리는 이곳에서 더 많은 자료를 발견하고 링크를 클릭하여 보았다 https://qiita.com/DinhDuyThanh/items/257d032bd1e167d0b5bc텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
우수한 개발자 콘텐츠 발견에 전념
(Collection and Share based on the CC Protocol.)