+8

Tạo mã QRCode chuyển tiền ngân hàng

Mở đầu

  • Hiện nay hầu hết các ứng dụng của ngân hàng đều hỗ trợ chúng ta tạo ra các mã QRCode chuyển khoản. Nó có ưu điểm giúp ta rút ngắn và thuận tiện hơn trong quá trình chuyển khoản.
  • Ngoài ra ta cũng có thể set được số tiền và nội dung chuyển khoản trên ứng dụng nhưng nó sẽ tĩnh.
  • Vậy bài viết hôm nay chúng ta sẽ cùng đi tìm cách tạo ra mã QRCode tùy chỉnh động được số tiền và nội dung mà ta muốn mà các ứng dụng của ngân hàng vẫn quét được.

image.png

Cách 1: Sử dụng API VietQR

VietQR là gì ?

VietQR là nhận diện thương hiệu chung dành cho các dịch vụ thanh toán, chuyển khoản bằng mã QR được xử lý qua mạng lưới NAPAS và các Ngân hàng thành viên, các trung gian thanh toán, các đối tác thanh toán trong và ngoài nước. VietQR tuân thủ tiêu chuẩn thanh toán QR của EMV Co. và bộ Tiêu chuẩn cơ sở cho mã QR do NHNN ban hành tại Quyết định số 1928/QĐ-NHNN.

Cách sử dụng API VietQR

Tài liệu của VietQR Bấm vào đây.

Cái chúng ta sẽ sử dụng là quicklink.

https://img.vietqr.io/image/<BANK_ID>-<ACCOUNT_NO>-<TEMPLATE>.png?amount=<AMOUNT>&addInfo=<DESCRIPTION>&accountName=<ACCOUNT_NAME>

Trong đó:

  • <BANK_ID>: Mã BIN ngân hàng, được quy định bởi ngân hàng nhà nước hoặc tên thường gọi phổ biến / tên viết tắt quy ước bởi NAPAS của ngân hàng bấm vào đây để xem.
  • <ACCOUNT_NO> : Số tài khoản người nhận tại ngân hàng thụ hưởng.
  • <TEMPLATE> : là hình thức trình bày của file ảnh chứa mã VietQR.
Theme Size Ý nghĩa
compact2 540x640 Bao gồm : Mã QR, các logo , thông tin chuyển khoản
compact 540x540 QR kèm logo VietQR, Napas, ngân hàng
qr_only 480x480 Trả về ảnh QR đơn giản, chỉ bao gồm QR
print 600x776 Bao gồm : Mã QR, các logo và đầy đủ thông tin chuyển khoản.
  • <AMOUNT> : Số tiền chuyển khoản ( tối đa 13 số).
  • <DESCRIPTION>: Nội dung chuyển khoản.
  • <ACCOUNT_NAME>: quy định tên người thụ hưởng hiển thị lên file ảnh VietQR. Trường này không nằm trong tiêu chuẩn tạo mã VietQR.

Ví dụ ta cần tạo 1 mã chuyển khoản 50k nội dung là test đến ngân hàng TPBank, số tài khoản là mynamebvh và sử dụng template compact2 link sẽ có dạng:

https://img.vietqr.io/image/tpbank-mynamebvh-compact2.jpg?amount=50000&addInfo=test&accountName=Bui%20Viet%20Hoang

Tiếp theo truy cập link trên và sử dụng 1 ứng dụng của ngân hàng bất kì và test thử.

Cách 2: Tự xây dựng

Ta có thể dựa vào tài liệu của VietQR để tự xây dựng bấm vào đây

Trong tài liệu có nhiều thành phần nhưng ta chỉ quan tâm đến QR động đến tài khoản ngân hàng.

Các thành phần chính

Ta sẽ lấy 1 ví dụ để giải thích.

00020101021238530010A000000727012300069704230109mynamebvh0208QRIBFTTA53037045405500005802VN62080804test6304AB76

Đây là nội dung mình phân tách ra cho ae dễ nhìn

000201
010212
38530010A000000727012300069704230109mynamebvh0208QRIBFTTA
5303704
540550000
5802VN
62080804test
6304AB76

Giải thích như ảnh dưới (do ví dụ mình đã sửa nên ảnh dưới ae bỏ qua cột giá trị nhé) image.png

Nội dung của mã QR động sẽ có các phần ghép lại tạo thành 1 nội dung hoàn chỉnh ( mỗi phần bao gồm mã ID, độ dài của giá trị và giá trị).

1. Payload Format Indicator:

Lấy 6 ký tự đầu của đoạn văn bản phía trên nó sẽ là 000210 -> ID: 00, Độ dài: 02, Giá trị: 01.

2. Point of Initiation Method:

Tiếp tục sẽ là 010212 -> ID: 01, Độ dài: 02, Giá trị: 12 (các phần dưới tương tự).

Giải thích giá trị:

  • 11 = QR tĩnh – áp dụng khi mã QR cho phép thực hiện nhiều lần giao dịch.
  • 12 = QR động – áp dụng khi mã QR chỉ cho phép thực hiện một lần giao dịch.

3. Consumer Account Information:

Tiếp tục sẽ là 38530010A000000727012300069704230109mynamebvh0208QRIBFTTA -> ID: 38, Độ dài: 53, Giá trị: 0010A000000727012300069704230109mynamebvh0208QRIBFTTA

Giá trị nó lại chia thành 3 phần:

  1. Định danh toàn cầu (GUID): 0010A000000727 -> ID: 00, Độ dài: 10, Giá trị: A000000727
  2. Tổ chức ngân hàng thụ hưởng: 012300069704230109mynamebvh -> ID: 01, Độ dài: 23, Giá trị: 00069704230109mynamebvh. Giá trị này lại chia làm 2 phần:
    1. Acquier ID/BNB ID: 0006970423 -> ID: 00, Độ dài: 06, Giá trị: 970423 (970423 chính là mã BIN TPBank).
    2. Merchant ID/Consumer ID: 0109mynamebvh, ID: 01, Độ dài: 09, Giá trị: mynamebvh (Chính là số tài khoản).
  3. Mã dịch vụ: 0208QRIBFTTA -> ID: 02, Độ dài: 08, Giá trị: QRIBFTTA (QRIBFTTA: dịch vụ chuyển nhanh NAPAS247 bằng mã QR đến Tài khoản)

4. Transaction Currency

5303704 -> ID: 53, Độ dài: 03, Giá trị: 704

Giải thích: 704 mã tiền tệ VN.

5. Transaction Amount

5406180000 -> ID: 54, Độ dài: 06, Giá trị: 180000

Đây là để set số tiền chuyển khoản.

6. Country Code

5802VN -> ID: 58, Độ dài: 02, Giá trị: VN

Cái này là mã quốc gia

7. Additional Data Field Template

62080804test -> ID: 62, Độ dài: 08, Giá trị: 0804test

Giá trị gồm: ID: 08, Độ dài 04, Giá trị: test (ID: 08 là Giá trị nhằm xác định mục đích của giao dịch, VD: nạp tiền điện thoại, mua hàng hóa… và test là nội dung chuyển khoản. Xem ID 62 ở tài liệu để biết thêm các ID khác ngoài ID 08.

8. CRC

6304AB76 -> ID: 63, Độ dài: 04, Giá trị: AB76 Đây là một phương pháp kiểm tra tính toàn vẹn dữ liệu trong việc truyền tải thông tin. Ở đây họ sử dụng CRC 0xFFFF. Cách tính là lấy nội dung của QRCode như ví dụ trên sẽ là 00020101021238530010A000000727012300069704230109mynamebvh0208QRIBFTTA53037045405500005802VN62080804test6304 rồi cho qua hàm tính CRC sẽ ra kết quả: AB76.

Bắt đầu xây dựng

Việc tạo nội dung mã QR này không hề khó nhưng dễ nhầm lẫn.

  1. Payload Format Indicator: Phần này ta để nguyên như ví dụ.
  2. Point of Initiation Method: Phần này ta cũng để nguyên như ví dụ -> vì ta cần QR động.
  3. Consumer Account Information:
    1. GUI giữ nguyên.
    2. Acquier ID/BNB ID: Sửa thành mã BIN ngân hàng thụ hưởng (dùng API của VietQR để lấy).
    3. Merchant ID/Consumer ID: Sửa số tài khoản thụ hưởng.
    4. Mã dịch vụ giữ nguyên: vì ta cần QR đến số tài khoản (nếu muốn đến thẻ thì đổi thành QRIBFTTC)
  4. Transaction Currency: Giữ nguyên.
  5. Transaction Amount: Sửa thành số tiền muốn chuyển.
  6. Country Code: Giữ nguyên.
  7. Additional Data Field Template: Sửa nội dung chuyển khoản.
  8. Tính CRC.

Sau đó ghép các phần lại với nhau và tạo QR là ta đã hoàn thành. Công việc còn lại chỉ là mang ứng dụng ngân hàng ra test.

Code tham khảo.

Chủ yếu demo cho mọi người nhấn vào đây nên cũng chưa validate hay check kĩ lỗi.


All rights reserved

Viblo
Hãy đăng ký một tài khoản Viblo để nhận được nhiều bài viết thú vị hơn.
Đăng kí