QRIS

Generate QRIS

Panduan lengkap untuk membuat QRIS menggunakan API Paylabs.

Request URL

URL: ${ROOT_URL}/payment/v2.3/qris/create

HTTPMethod: POST

EndpointUrl: /payment/v2.3/qris/create

Generate QRIS Request Parameters

Cara Membuat Signature

Field NameTypeValueRequired
Content-TypeString(30)Isi dengan nilai "application/json;charset=utf-8"Yes
X-TIMESTAMPString(29)Waktu saat ini, dengan format 2022-09-16T16:58:47.964+07:00Yes
X-SIGNATUREString(64)Signature. Untuk selengkapnya cekYes
X-PARTNER-IDString(20)Merchant IDYes
X-REQUEST-IDString(64)ID unik merepresentasikan setiap request yang dikirimYes

Body

ParameterTypeRequiredRemarks
requestIdString(64)YesKode unik untuk setiap request
merchantIdString(20)YesID unik yang disediakan oleh payment gateway ke merchant
storeIdString(30)NoJika Merchant memiliki cabang dan ingin membuat order dengan ID cabang
paymentTypeString(20)YesNama tipe pembayaran, cek tabel Tipe Pembayaran
amountDecimal(12,2)YesNominal dalam Rupiah Indonesia
merchantTradeNoString(32)YesKode unik yang dibuat oleh Merchant untuk setiap transaksi
notifyUrlString(200)NoURL yang akan ditembak saat terjadi pembayaran. Untuk parameter-parameternya cek di bagian Inquiry Order
expireNumberNoSatuan adalah detik, tidak didukung, saluran yang berbeda memiliki nilai default yang berbeda
feeTypeString(3)NoJenis pengurangan biaya layanan:BEN、OURStandarnya adalah BEN. Ketika OUR dipilih, biaya layanan akan ditambahkan ke nominal order secara otomatis.
productNameString(100)YesNama layanan atau produk
+productInfoArray<Object>(30)NoInformasi detil atas produk atau layanan dalam transaksi
「idString(10)YesProduct ID
「nameString(32)YesProduct Name
「pricedecimal(12,2)YesNilai dalam Rupiah, mendukung dua angka belakang koma
「typeString(20)YesProduct Type
「urlString(200)NoProduct URL
「quantityNumber(4)YesProduct Quantity

paymentType

Payment TypeCode
QRISQRIS

Generate QRIS Response Parameters

Header

Cara Membuat Signature

Field NameTypeValueRequired
Content-TypeString(30)Isi dengan nilai "application/json;charset=utf-8"Yes
X-TIMESTAMPString(29)Waktu saat ini, dengan format 2022-09-16T16:58:47.964+07:00Yes
X-SIGNATUREString(64)Signature. Untuk selengkapnya cekYes
X-PARTNER-IDString(20)Merchant IDYes
X-REQUEST-IDString(64)ID unik merepresentasikan setiap request yang dikirimYes

Body

Kode Error

ParameterTypeRequiredRemarks
requestIdString(64)YesKode unik untuk setiap request
errCodeString(32)Yes0 adalah sukses, untuk lainnya bisa lihat tabel
errCodeDesString(128)NoDeskripsi terkait error
merchantIdString(20)YesMerchant ID
storeIdString(30)NoHanya diisi jika perlu menggunakan akun channel cabang
paymentTypeString(20)YesNama dari Jenis Pembayaran, cek tabel Jenis Pembayaran
requestAmountDecimal(12,2)NoNominal pada saat permintaan
amountDecimal(12,2)YesNominal dalam Rupiah Indonesia, with 2 decimal placesJenis pengurangan biaya layanan:Ketika OUR dipilih, biaya layanan akan ditambahkan ke nominal order. Ketika biaya layanan yang dihitung mengandung desimal, biaya layanan akan otomatis +1 setelah menghilangkan desimal. Misalnya, 10.000,11 akan secara otomatis +1 untuk mendapatkan 10.001,00.
merchantTradeNoString(32)YesKode unik yang dibuat oleh Merchant untuk setiap transaksi
createTimeString(16)NoyyyyMMddHHmmss
qrCodeString(300)NoThe code that can be converted to QRIS
qrisUrlString(300)NoQRIS image link
nmidString(32)NoNational Merchant ID
platformTradeNoString(32)NoNomor order di platform Paylabs
successTimeString(16)NoyyyyMMddHHmmss
expiredTimeString(16)NoyyyyMMddHHmmss
statusString(32)No01: Pending, 09: Failed, 02: Success
productNameString(100)YesNama layanan atau produk
rrnString(32)NoRRN, kode pembayaran sukses
tidString(32)NoTerminal ID or POS ID
payerString(60)NoNama dari payer yang sebenarnyaJika jenis pembayaran didukung, nama pembayar akan dikembalikan. Jika tidak didukung, nilai null akan dikembalikan.Saat ini hanya mendukung: QRISCatatan: Bukan “payer” yang dikirim oleh merchant saat memulai permintaan.
phoneNumberString(20)NoNomor telepon pembayar
issuerIdString(20)NoID dari aplikasi Issuer
+productInfoArray<Object>(30)NoInformasi detil atas produk atau layanan dalam transaksi
「idString(10)YesProduct ID
「nameString(32)YesProduct Name
「pricedecimal(12,2)YesNilai dalam Rupiah, mendukung dua angka belakang koma
「typeString(20)YesProduct Type
「urlString(200)NoProduct URL
「quantityNumber(4)YesProduct Quantity
transFeeRateDecimal(6,6)NoRate Transaksi, mendukung enam angka belakang koma
transFeeAmountDecimal(12,2)NoBiaya, mendukung dua angka belakang koma
totalTransFeeDecimal(12,2)NoTotal rate biaya layanan transaksi (tidak termasuk vatFee), mendukung dua angka belakang koma
vatFeeDecimal(12,2)NoPajak, mendukung dua angka belakang koma
accountNoString(32)NoNomor rekening dari payer yang sebenarnyaJika jenis pembayaran didukung, nomor rekening pembayar akan dikembalikan. Jika tidak didukung, nilai null akan dikembalikan.Tidak ada metode pembayaran yang tersedia saat ini

Example

Request

POST /payment/v2.3/qris/create
# HTTP Header
Content-Type: application/json;charset=utf-8
X-TIMESTAMP: 2022-09-16T16:58:47.964+07:00
X-SIGNATURE: xxxxxxxxx
X-PARTNER-ID: 010001
X-REQUEST-ID: xxxxxxxxxxxxxxxxxxxxxxxx

# HTTP Body
{
  "merchantId":"0010001",
  "merchantTradeNo":"100100011649756102739",
  "requestId":"200100011649756102739",
  "paymentType":"QRIS",
  "amount":"10000.00",
  "productName":"Test"
}

Response

POST /payment/v2.3/qris/create
# HTTP Header
Content-Type: application/json;charset=utf-8
X-TIMESTAMP: 2022-09-16T16:58:47.964+07:00
X-SIGNATURE: xxxxxxxxx
X-PARTNER-ID: 010001
X-REQUEST-ID: xxxxxxxxxxxxxxxxxxxxxxxx

# HTTP Body
{
  "amount":"10000.00",
  "merchantTradeNo":"100100011649756102739",
  "platformTradeNo":"2022041200000000026",
  "expiredTime":"20220412163603",
  "paymentType":"QRIS",
  "qrCode":"00020101021226610016ID.CO.PAYLABS.WWW01189360091800200340760208200340760303UMI520467895303360540810000.005802ID5918Paylabs Test Store6015KOTA JAKARTA BA6105111116223051920220412000000000266304741E",
  "createTime":"20220412163504",
  "merchantId":"0010001",
  "errCode":"0",
  "requestId":"200100011649756102739",
  "productName":"Test",
  "status":"01",
  "transFeeRate":"0",
  "transFeeAmount":"0",
  "totalTransFee":"0",
  "vatFee":"0"
}