composer require sanmai/ gmopg
มีสองวิธีในการกำหนดค่า API:
ด้วยค่าคงที่โกลบอล กล่าวคือคุณต้องกำหนด:
// ショップ情報
define ( ' GMO_SHOP_ID ' , ' tshop0000001 ' ); // ショップID
define ( ' GMO_SHOP_PASSWORD ' , ' qwerty ' ); // ショップ名
define ( ' GMO_SHOP_NAME ' , ' My Shop ' ); // ショップパスワード
define ( ' GMO_TRIAL_MODE ' , false );
คุณสามารถรับสามรายการแรกได้จากแผงการจัดการหรือจากอีเมลจาก GMO PG
ค่าคงที่ GMO_TRIAL_MODE
สุดท้ายควรตั้งค่าเป็น true
หากคุณใช้รหัสผ่านร้านค้าทดสอบ
โดยการเรียกวิธีการคงที่เหล่านี้:
GMO API Defaults:: setShopID ( $ shopId );
GMO API Defaults:: setShopName ( $ shopName );
GMO API Defaults:: setPassword ( $ shopPassword );
// When using a test password, this constant is mandatory
//define('GMO_TRIAL_MODE', true);
ขณะนี้ไม่มีวิธีอื่นในการเปิดใช้งานโหมดทดสอบอื่นใดนอกจากการกำหนดค่า GMO_TRIAL_MODE
คงที่ซึ่งตั้งค่าเป็น true
define ( ' GMO_TRIAL_MODE ' , true );
การทดสอบการชำระเงินด้วยหมายเลขบัตรที่ป้อนโดยตรงพร้อมข้อมูลรับรองสภาพแวดล้อมการทดสอบ กำหนดให้คุณต้องเปิดใช้งานการชำระเงินดังกล่าวตามที่ระบุไว้ในเอกสารประกอบ
// A wrapper object that does everything for you.
$ payment = new GMO ImmediatePayment ();
// Unique ID for every payment; probably should be taken from an auto-increment field from the database.
$ payment -> paymentId = 123 ;
$ payment -> amount = 1000 ;
// This card number can be used for tests.
$ payment -> cardNumber = ' 4111111111111111 ' ;
// A date in the future.
$ payment -> cardYear = ' 2020 ' ;
$ payment -> cardMonth = ' 7 ' ;
$ payment -> cardCode = ' 123 ' ;
// Returns false on an error.
if (! $ payment -> execute ()) {
$ errors = $ payment -> getErrors ();
foreach ( $ errors as $ errorCode => $ errorDescription ) {
// Show an error code and a description to the customer? Your choice.
// Probably you want to log the error too.
}
return ;
}
// Success!
$ response = $ payment -> getResponse ();
/** @var GMOAPIResponseExecTranResponse $response */
// You would probably want to save the response in the database for future reference.
// The response can be used to query details about a transaction, make refunds and so on.
อาร์เรย์ของ $errors
มาในรูปแบบที่คล้ายกับสิ่งนี้:
array(1) {
'E01040010' =>
string(34) "This order ID was used previously."
}
รายการรหัสข้อผิดพลาดที่รู้จักมากที่สุด ในรูปแบบที่สามารถอ่านได้ และอีกอย่าง
$response
โดยทั่วไปจะมีลักษณะดังนี้:
class GMOAPIResponseExecTranResponse#1 (9) {
public $ACS =>
string(1) "0"
public $OrderID =>
string(10) "1517000000"
public $Forward =>
string(7) "0afd1200"
public $Method =>
string(1) "1"
public $PayTimes =>
string(0) ""
public $Approve =>
string(7) "0112234"
public $TranID =>
string(28) "180111111111111111111344439"
public $TranDate =>
string(14) "20221222213141"
public $CheckString =>
string(32) "68b329da9893e34099c7d8ad5cb9c940"
}
ออบเจ็กต์การชำระเงินสามารถรับโทเค็นที่ได้รับจาก JavaScript API แทนรายละเอียดบัตรเครดิตได้:
$ payment = new GMO ImmediatePayment ();
$ payment -> paymentId = 123 ; // Unique ID for every payment; see above
$ payment -> amount = 1000 ;
// Card details are unnecessary in this case
$ payment -> token = $ _POST [ ' token ' ];
if (! $ payment -> execute ()) {
// ... same as above
}
// ... same as above
ควรใช้วิธีการชำระเงินข้างต้น หากได้รับข้อผิดพลาดที่น่าเชื่อถือ E61040001
ตอนนี้คุณต้องการโหลดรายละเอียดธุรกรรมสำหรับการชำระเงินปัจจุบันโดยธรรมชาติ
$ searchTrade = new GMO API Call SearchTrade ();
$ searchTrade -> OrderID = $ payment -> getResponse ()-> OrderID ;
// Copy credential from the original payment
$ payment -> setupOther ( $ searchTrade );
$ response = $ searchTrade -> dispatch ();
ใน $response
นี้ คุณจะพบช่องเหล่านี้:
class GMOAPIResponseSearchTradeResponse#4950 (21) {
public $AccessID =>
string(32) "b026324c6904b2a9cb4b88d6d61c81d1"
public $AccessPass =>
string(32) "26ab0db90d72e28ad0ba1e22ee510510"
public $OrderID =>
string(10) "1517000000"
public $Status =>
string(5) "SALES"
public $ProcessDate =>
string(14) "20221222213141"
public $JobCd =>
string(5) "SALES"
public $ItemCode =>
string(7) "0000000"
public $Amount =>
string(4) "4999"
public $Tax =>
string(1) "0"
public $SiteID =>
string(0) ""
public $MemberID =>
string(0) ""
public $CardNo =>
string(16) "************1111"
public $Expire =>
string(4) "2307"
public $Method =>
string(1) "1"
public $PayTimes =>
string(0) ""
public $Forward =>
string(7) "0afd1200"
public $TranID =>
string(28) "180111111111111111111344439"
public $Approve =>
string(7) "0112234"
public $ClientField1 =>
string(0) ""
public $ClientField2 =>
string(0) ""
public $ClientField3 =>
string(0) ""
}
GMO-PG ดูเหมือนจะเป็นความลับมากโดยไม่มีเหตุผลเลย (ซึ่งตรงกันข้ามกับ Stripe โดยสิ้นเชิง) และโดยทั่วไปแล้วคุณจะสามารถเข้าถึงเอกสารของพวกเขาได้ก็ต่อเมื่อลงนามในข้อตกลงไม่เปิดเผยข้อมูลเท่านั้น