Payment Gateway Integration in Java
Integrate Zaakpay Payment Gateway using our Java Kit in a few minutes. Just follow our getting started guide and Integrate Zaakpay Java Kit today.
Haven't created your account yet?Please follow our Getting started guide.
1. Installing The Kit
- Download Zaakpay Payment Gateway Java Kit
2. Initiating Payment
- Request parameters must be provided at your site that will further pass to the processPayment() ( Transaction.java ) for further payment process.
public ZaakpayApiRequestParameters processPayment() throws Exception {
        ZaakpayApiRequestParameters zaakpayApiRequestParameters = new ZaakpayApiRequestParameters();
        String requestUrl = Config.ENVIRONMENT+Config.TRANSACTION_API_URL;
        zaakpayApiRequestParameters.setRequestUrl(requestUrl);
        //You can pass these values dynamically through function arguments
        String orderId = "ZPLive"+System.currentTimeMillis();
        String amount = "100" ; //In Paisa
        RequestParameters order = new RequestParameters(Config.ZAAKPAY_MERCHANT_IDENTIFIER,Config.RETURN_URL,orderId,amount);
        zaakpayApiRequestParameters.setRequestParameters(order.getPaymentRequestParameters());
        String checksumString = ChecksumGenerator.getChecksumString(order.getPaymentRequestParameters()) ;
        // System.out.println(checksumString);
        // You can check the checksum string generated here.
        String checksum = ChecksumGenerator.calculateChecksum(Config.ZAAKPAY_SECRET_KEY,checksumString);
        zaakpayApiRequestParameters.setChecksum(checksum);
        return zaakpayApiRequestParameters ;
    }- To check the optional and mandatory parameters please refer to this Documentation.
You can also add/remove the optional parameters from getPaymentRequestParameters() ( RequestParameters.java ) .
public TreeMap<String,String> getPaymentRequestParameters() {
        TreeMap<String,String> requestParams = new TreeMap<String, String>();
        //Using TreeMap to pass the parameters in a sorted way to ensure the checksum sequence
        //***********Mandatory Parameters************//
        requestParams.put("orderId",orderId);
        requestParams.put("amount",amount);
        requestParams.put("buyerEmail",buyerEmail);
        requestParams.put("currency",currency);
        requestParams.put("merchantIdentifier",merchantIdentifier);
        //*******************************************//
        //You can add optional parameters in a similar way
        return requestParams;
    }- All the request parameters including the checksum further redirect to the Zaakpay using the post request as mentioned in Transaction.java .
Also you can print the checksum string and calculated checksum .
public static String getChecksumString(TreeMap<String,String> requestParam) {
        String checksumString = "" ;
        for (Map.Entry<String,String> param: requestParam.entrySet()) {
            checksumString=checksumString+param.getKey()+"="+param.getValue();
            checksumString=checksumString+"&";
            //This will create the checksum string against every parameter.
        }
        return checksumString;
    }
Transaction Failing ?Make sure you are using Live cards for Live Transactions.
- Once the transaction got completed you will get the Zaakpay's Callback to the path you had provided on returnUrl.
public String[] getResponseParameters ()
    {
        String[] responseParam = {"amount","bank","bankid","cardId",
                "cardScheme","cardToken","cardhashid","doRedirect","orderId",
                "paymentMethod","paymentMode","responseCode","responseDescription",
                "productDescription","product1Description","product2Description",
                "product3Description","product4Description","pgTransId","pgTransTime"} ;
        //These are the response parameters you will get in the final callback from Zaakpay.
        return responseParam;
    }( By default it will redirect to  Zaakpay's test response page )
Unable to get Response ?Please check the Return URL ( Response file path ) is correct and reachable.
3. Featured API's
- 
Check API This is used to check the status of the transaction.\ 
public ZaakpayApiRequestParameters checkStatus( String orderId) throws Exception {
        ZaakpayApiRequestParameters zaakpayApiRequestParameters = new ZaakpayApiRequestParameters();
        String requestUrl = Config.ENVIRONMENT+Config.TRANSACTION_STATUS_API_URL;
        zaakpayApiRequestParameters.setRequestUrl(requestUrl);
        RequestParameters checkStatus = new RequestParameters(orderId,Config.ZAAKPAY_MERCHANT_IDENTIFIER);
        zaakpayApiRequestParameters.setRequestParameters(checkStatus.getTransactionStatusRequestParameters());
        String checksumString = checkStatus.getTransactionStatusRequestParameters().get("formRequestData");
        // System.out.println(checksumString);
        // You can check the checksum string generated here.
        String checksum = ChecksumGenerator.calculateChecksum(Config.ZAAKPAY_SECRET_KEY,checksumString);
        zaakpayApiRequestParameters.setChecksum(checksum);
        return zaakpayApiRequestParameters;
    }Such that passing the above parameters to checkStatus(String orderId) ( Transaction.java ) you can check the status of the transaction.
public Map<String,String> getTransactionStatusRequestParameters()
    {
        Map<String ,String > requestParams = new HashMap<String, String>();
        requestParams.put("merchantIdentifier",merchantIdentifier);
        requestParams.put("orderId",orderId);
        //You can also pass JSON object here to submit in final form request or you can use the below format string
        requestParams.put("formRequestData","{merchantIdentifier:"+merchantIdentifier+",mode:"+mode+",orderDetail:{orderId:"+orderId+"}}");
        return requestParams;
    }Also checksum would be calculated on the json data as checksum string.
- 
Refund API This is used to refund the transaction. You can either initaite full refund or partial refund against a particular transaction. 
public ZaakpayApiRequestParameters initiateFullRefund(String orderId) throws Exception {
        ZaakpayApiRequestParameters zaakpayApiRequestParameters = new ZaakpayApiRequestParameters();
        String requestUrl = Config.ENVIRONMENT+Config.UPDATE_API_URL;
        zaakpayApiRequestParameters.setRequestUrl(requestUrl);
        String updateReason = "Test Reason";
        RequestParameters refund = new RequestParameters(Config.ZAAKPAY_MERCHANT_IDENTIFIER,null,orderId,"14",updateReason);
        zaakpayApiRequestParameters.setRequestParameters(refund.getFullRefundRequestParameters());
        String checksumString = ChecksumGenerator.getUpdateChecksumString(refund.getFullRefundRequestParameters());
        // System.out.println(checksumString);
        // You can check the checksum string generated here.
        String checksum = ChecksumGenerator.calculateChecksum(Config.ZAAKPAY_SECRET_KEY,checksumString);
        zaakpayApiRequestParameters.setChecksum(checksum);
        return zaakpayApiRequestParameters;
    }public ZaakpayApiRequestParameters initiatePartialRefund(String orderId , String amount) throws Exception {
        ZaakpayApiRequestParameters zaakpayApiRequestParameters = new ZaakpayApiRequestParameters();
        String requestUrl = Config.ENVIRONMENT+Config.UPDATE_API_URL;
        zaakpayApiRequestParameters.setRequestUrl(requestUrl);
        String updateReason = "Test Reason";
        RequestParameters refund = new RequestParameters(Config.ZAAKPAY_MERCHANT_IDENTIFIER,amount,orderId,"22",updateReason);
        zaakpayApiRequestParameters.setRequestParameters(refund.getPartialRefundRequestParameters());
        String checksumString = ChecksumGenerator.getUpdateChecksumString(refund.getPartialRefundRequestParameters());
        // System.out.println(checksumString);
        // You can check the checksum string generated here.
        String checksum = ChecksumGenerator.calculateChecksum(Config.ZAAKPAY_SECRET_KEY,checksumString);
        zaakpayApiRequestParameters.setChecksum(checksum);
        return zaakpayApiRequestParameters;
    }Also the checksum string generated here would be a concatenated string all the parameters seperated by single courses as mentioned below .
public static String getUpdateChecksumString(Map<String,String> requestParam) {
        String checksumString = "" ;
        for (Map.Entry<String,String> param: requestParam.entrySet()) {
            checksumString=checksumString+"\'"+param.getValue()+"\'";
            //This will create the checksum string against every parameter.
        }
        return checksumString;
    }Updated 4 months ago
