These docs are for v3.2.6. Click to read the latest docs for v4.3.0.

Alternative Payment Methods

👍

Download Sample Code

PHP Code

🚧

This option only applicable for Server-to-Browser mode

📘

Environment

Please refer Demo & Live Endpoint.

Set account credentials

<?php 
	//Merchant's account information
	$merchantID = "JT01";		//Get MerchantID when opening account with 2C2P
	$secretKey = "7jYcp4FxFdf0";	//Get SecretKey from 2C2P PGW Dashboard

Set transaction information.

//Transaction Information
	$desc = "2 days 1 night hotel room";
	$uniqueTransactionCode = time();
	$currencyCode = "702";
	$amt  = "000000000010";

Set to APM payment mode

Set payment option

🚧

All APM information must be included in hash compute value

//Payment Options
	$paymentChannel = "123";		//Set transaction as Alternative Payment Method
	$agentCode = "AXS";			//APM agent code
	$channelCode = "KIOSK";			//APM channel code
	$paymentExpiry = (new DateTime('today'))->format("Y-m-d 23:59:59");	//pay slip expiry date (optional). format yyyy-MM-dd HH:mm:ss
	$mobileNo = "812348888";		//customer mobile number
	$cardholderEmail = "[email protected]";	//customer email address
Variable NameDescription
paymentChannelPayment channels option code
agentCodeAPM Agent Codes
channelCodeAPM Channel Codes

If channel Code is left blank, system will use default value "OVERTHECOUNTER".
paymentExpiryPayment Slip Expiry, Allows merchant to specify payment expiry date/time for APM service,
Format: yyyy-MM-dd HH:mm:ss,
Default for expiry will be merchant configuration in APM system.
mobileNoCustomer's mobile number, mandatory for APM payment.
cardHolderEmailCustomer's email address, mandatory for APM payment.

Set payment request information

//Request Information 
	$version = "9.9";

Construct payment request message

//Construct payment request message
	$xml = "<PaymentRequest>
		<merchantID>$merchantID</merchantID>
		<uniqueTransactionCode>$uniqueTransactionCode</uniqueTransactionCode>
		<desc>$desc</desc>
		<amt>$amt</amt>
		<currencyCode>$currencyCode</currencyCode>  
		<panCountry>$panCountry</panCountry> 
		<cardholderName>$cardholderName</cardholderName>
		<paymentChannel>$paymentChannel</paymentChannel>
		<agentCode>$agentCode</agentCode>
		<channelCode>$channelCode</channelCode>
		<paymentExpiry>$paymentExpiry</paymentExpiry>
		<mobileNo>$mobileNo</mobileNo>
		<cardholderEmail>$cardholderEmail</cardholderEmail>
		<encCardData>$encCardData</encCardData>
		</PaymentRequest>"; 
  $paymentPayload = base64_encode($xml); //Convert payload to base64
  $signature = strtoupper(hash_hmac('sha256', $paymentPayload, $secretKey, false));
  $payloadXML = "<PaymentRequest>
           <version>$version</version>
           <payload>$paymentPayload</payload>
           <signature>$signature</signature>
           </PaymentRequest>"; 
  $payload = base64_encode($payloadXML); //encode with base64
?>

Submit payment request form

<form action='https://demo2.2c2p.com/2C2PFrontEnd/SecurePayment/PaymentAuth.aspx' method='POST' name='paymentRequestForm'>
	Processing payment request, Do not close the browser, press back or refresh the page. 
	<?php echo "<input type='hidden' name='paymentRequest' value='".$payload."'>"; ?>
</form>
<script language="JavaScript">
	document.paymentRequestForm.submit();	//submit form to 2c2p PGW
</script>

Complete Code
Copy & Paste below file code and put this file in your Web Server.

<?php 
	//Merchant's account information
	$merchantID = "JT01";		//Get MerchantID when opening account with 2C2P
	$secretKey = "7jYcp4FxFdf0";	//Get SecretKey from 2C2P PGW Dashboard

	//Transaction Information
	$desc = "2 days 1 night hotel room";
	$uniqueTransactionCode = time();
	$currencyCode = "702";
	$amt  = "000000000010";

	//Payment Options
	$paymentChannel = "123";		//Set transaction as Alternative Payment Method
	$agentCode = "AXS";			//APM agent code
	$channelCode = "KIOSK";			//APM channel code
	$paymentExpiry = (new DateTime('today'))->format("Y-m-d 23:59:59");	//pay slip expiry date (optional). format yyyy-MM-dd HH:mm:ss
	$mobileNo = "81238888";		//customer mobile number
	$cardholderEmail = "[email protected]";	//customer email address
	
	//Request Information 
	$version = "9.9";
   
	//Construct payment request message
	$xml = "<PaymentRequest>
		<merchantID>$merchantID</merchantID>
		<uniqueTransactionCode>$uniqueTransactionCode</uniqueTransactionCode>
		<desc>$desc</desc>
		<amt>$amt</amt>
		<currencyCode>$currencyCode</currencyCode>  
		<panCountry>$panCountry</panCountry> 
		<cardholderName>$cardholderName</cardholderName>
		<paymentChannel>$paymentChannel</paymentChannel>
		<agentCode>$agentCode</agentCode>
		<channelCode>$channelCode</channelCode>
		<paymentExpiry>$paymentExpiry</paymentExpiry>
		<mobileNo>$mobileNo</mobileNo>
		<cardholderEmail>$cardholderEmail</cardholderEmail>
		<encCardData>$encCardData</encCardData>
		</PaymentRequest>"; 
  $paymentPayload = base64_encode($xml); //Convert payload to base64
  $signature = strtoupper(hash_hmac('sha256', $paymentPayload, $secretKey, false));
  $payloadXML = "<PaymentRequest>
           <version>$version</version>
           <payload>$paymentPayload</payload>
           <signature>$signature</signature>
           </PaymentRequest>"; 
  $payload = base64_encode($payloadXML); //encode with base64
?>

<form action='https://demo2.2c2p.com/2C2PFrontEnd/SecurePayment/PaymentAuth.aspx' method='POST' name='paymentRequestForm'> 
	Processing payment request, Do not close the browser, press back or refresh the page. 
	<?php echo "<input type='hidden' name='paymentRequest' value='".$payload."'>"; ?>
</form>
<script language="JavaScript">
	document.paymentRequestForm.submit();	//submit form to 2c2p PGW
</script>

Next: Advanced payment options